九色成人免费视频_久久一区视频_视频一区国产精品_精品视频在线观看

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

Session服務器配置指南與使用經驗

發布時間:  2012/5/24 20:38:47

一.摘要

所有Web程序都會使用Session保存數據. 使用獨立的Session億恩科技服務器可以解決負載均衡場景中的Session共享問題.本文介紹.NET平臺下建立Session億恩科技服務器的幾種辦法, 并介紹在使用Session時的各種經驗和技巧.

二.關于Session,SessionID和Cookies

Session數據保存在億恩科技服務器端, 但是每一個客戶端都需要保存一個SessionID, SessionID保存在Cookies中, 關閉瀏覽器時過期.

在向億恩科技服務器發送的HTTP請求中會包含SessionID, 億恩科技服務器端根據SessionID獲取獲取此用戶的Session信息.

很多初級開發人員不知道SessionID和Cookies的關系, 所以常常認為兩者沒有聯系. 這是不正確的. 正是因為SessionID保存在Cookies中, 所以在我們保存Cookies的時候,一定要注意不要因為Cookies的大小和個數問題而導致SessionID對象. 在我們的程序中, 對SessionID的Cookies有特殊的處理:

/// <summary>
/// 寫入cookie.
/// </summary>
/// <param name="day"></param>
/// <returns></returns>
public bool SetCookie(int day)
{
string CookieName = GetType().ToString();
HttpCookie SessionCookie = null;

//對 SessionId 進行備份.
if (HttpContext.Current.Request.Cookies["ASP.NET_SessionId"] != null)
{
string SesssionId = HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value.ToString();
SessionCookie = new HttpCookie("ASP.NET_SessionId");
SessionCookie.Value = SesssionId;

}

//省略掉中間的代碼部分.只保留備份SessionID和找回SessionID的邏輯

//如果cookie總數超過20 個, 重寫ASP.NET_SessionId, 以防Session 丟失.
if (HttpContext.Current.Request.Cookies.Count > 20 && SessionCookie != null)
{
if (SessionCookie.Value != string.Empty)
{
HttpContext.Current.Response.Cookies.Remove("ASP.NET_SessionId");
HttpContext.Current.Response.Cookies.Add(SessionCookie);
}
}

return true;
}
三.搭建Session億恩科技服務器的幾種方式

將Session保存在獨立的億恩科技服務器中可以實現在多臺Web億恩科技服務器之間共享Session.雖然我們也可以自己開發Session存儲系統, 但是使用ASP.NET自帶的存儲機制將更加便捷.

.NET提供了5種保存Seission的方式:

方式名稱

存儲方式 性能

Off

設置為不使用Session功能

InProc

設置為將Session存儲在進程內,就是ASP中的存儲方式,這是默認值。

性能最高

StateServer

設置為將Session存儲在獨立的狀態服務中。通常是aspnet_state.exe進程.

性能損失10-15%

SQLServer

設置將Session存儲在SQL Server中。

性能損失10-20%

Customer

自定制的存儲方案

由實現方式確定

我們可以在Web.Config中配置程序使用的Session存儲方式.默認情況下是InProc, 即保存在IIS進程中. 關于Off, InProc和Customer本文不做講解. 相關文章大家都可以在網上搜索到.

下面主要講解 StateServer 和 SQLServer 的應用.

四.使用 StateServer 模式搭建Session億恩科技服務器

(1)億恩科技服務器端配置

1.啟動 Asp.net State service服務.(這個服務默認的狀態為手動.修改為自動并啟動.)

2.修改注冊表: [HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\aspnet_state\Parameters]

設置 AllowRemoteConnection = 1 , 設置 Port = 42424 (十進制,默認即為42424)

Port是服務的端口號

AllowRemoteConnection 表示是否允許其他機器連接,0為僅能本機使用,1為可以供其他機器使用.

(2)客戶端設置

在Web應用程序的Web.Config中, 我們需要修改 / 的節點.如果沒有

沒有則添加(默認使用的是InProc方式)

mode="StateServer"

stateConnectionString="tcpip=億恩科技服務器ip:42424"

cookieless="false"

timeout="60"/>

上面的參數我們可以根據需要修改.
 

五.使用SqlServer模式搭建Session億恩科技服務器

(1)億恩科技服務器端配置

使用SqlServer模式搭建Session億恩科技服務器端有兩種方式. ASP.NET 1.0和1.1版本請使用方式a, 2.0即以上版本請使用方式b.

a.使用SQL文件創建Session數據庫

在ASP.NET 1.0和1.1 版本中, 只能使用這種方式.對于2.0及其以上版本,請使用aspnet_regsql.exe工具.(當然此方法也通用2.0版本)

.net提供了數據庫安裝腳本,可以在機器的windows文件夾中找到:

C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\ InstallSqlState.sql

C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\ InstallSqlStateTemplate.sql

根據ASP.NET的版本不同, 需要使用不同的SQL腳本. ASP.NET主要有1.1和2.0兩個版本,可以在不同的版本文件夾找到這兩個SQL.

InstallSqlState.sql 是創建默認名稱的數據庫"[ASPState]".此SQL可以直接運行.

InstallSqlStateTemplate.sql 可以使用自己指定的數據庫保存數據.此SQL需要自己修改后運行, 打開SQL文件將其中 [DatabaseNamePlaceHolder] 替換為自己指定的數據庫名稱.

執行installsqlstate.sql時不需要指定數據庫,可以在任意數據庫上執行.此SQL會自己創建新的數據庫

b. 使用aspnet_regsql.exe工具

ASP.NET 2.0版本后微軟提供了aspnet_regsql.exe工具可以方便的配置Session數據庫.該工具位于 Web 億恩科技服務器上的"系統根目錄\Microsoft.NET\Framework\版本號"文件夾中.

使用舉例:

aspnet_regsql.exe -S . -U sa -P 123456 -ssadd -sstype p

-S參數:

表示數據庫實例名稱. 可以用"."表示本機.

-U和-P參數:

表示用戶名和密碼.

-E參數:

可以再-U –P 與 -E中選擇一組. –E表示以當前系統用戶通過windows身份驗證登錄數據庫, -U -P則是使用SqlServer用戶登錄數據庫.

-ssadd / –ssremove 參數:

-ssadd表示是添加Session數據庫, -ssremove表示移除Session數據庫.

sstype 參數:

選項

說明

t

將會話數據存儲到 SQL Server tempdb 數據庫中。這是默認設置。如果將會話數據存儲到 tempdb 數據庫中,則在重新啟動 SQL Server 時將丟失會話數據。

p

將會話數據存儲到 ASPState 數據庫中,而不是存儲到 tempdb 數據庫中。

c

將會話數據存儲到自定義數據庫中。如果指定 c 選項,則還必須使用 -d 選項包括自定義數據庫的名稱。

(2)Session客戶端設置

此房是同樣需要Web應用程序修改Web.Config中的節點.如果使用默認的數據庫(ASPState庫), 則配置如下:

<sessionState
mode="SQLServer"
sqlConnectionString="server=192.168.9.151; uid=sa; pwd=123456;"
/>

如果使用了自定義的數據庫名稱,則還需要制定allowCustomSqlDatabase屬性并在數據庫連接串中指定數據庫:

<sessionState
mode="SQLServer"
allowCustomSqlDatabase="true"
sqlConnectionString="server=192.168.9.151; DataBase=MyAspState;uid=sa; pwd=123456;"
/>

六.使用經驗與技巧總結

下面是SessionID, Session_End時間, StatServer模式 和 SqlServer模式的各種經驗和技巧總結.

(1)StateServer模式:

1.在web farm中,請確認在所有的web億恩科技服務器上有相同的

2. 要保存在Session中的對象是可序列化的。

3.為了在web farm中的不同web億恩科技服務器上維護session state,IIS Metabase中的網站:(www.23lll.com)應用程序路徑(如\LM\W3SVC\2)應該在所有的億恩科技服務器上保持一致(大小寫敏感).

4. ASP.NET處理Session是在Machine.Config中配置的HttpModuel模塊, 在.NET的安裝目錄下的Config文件夾中, 查看Web.Config(1.1版本是在Machine.Config):

<httpModules>
...

 <add name="Session" type="System.Web.SessionState.SessionStateModule"/> ...
 </httpModules>

確認此模塊是否存在.
 

5.StateServer不支持負載均衡, 所以如果大并發推薦使用SqlServer模式, 可以享受到SqlServer的高性能和安全性.雖然存儲效率會有下降.

6.需要讓所有機器的MachineKey相同.在Machine.Config中配置:

<machineKey
validationKey="1234567890123456789012345678901234567890AAAAAAAAAA"
decryptionKey="123456789012345678901234567890123456789012345678"
validation="SHA1"
decryption="Auto"
/>

(2)SqlServer模式:

1. 要保存在Session中的對象是可序列化的。

2. 如果使用了默認是數據庫, 則在客戶端配置文件中的數據庫鏈接字符串的用戶,需要擁有ASPState和tempdb兩個庫的dbowner權限.

3. 在SQLServer模式下,session過期是由SQL Agent使用一個注冊任務完成的,要確認SQL Agent已經運行。否則無法清理過期的Session數據, 會導致數據庫數據一直增加.

4. 如果使用SqlServer模式時, 對于Web場中的各億恩科技服務器的 ASP.NET 應用程序路徑必須是相同的。請在 IIS 配置數據庫中對 Web 場中的所有 Web 億恩科技服務器進行 Web 站點的應用程序路徑同步。大小寫一定要相同,因為 Web 站點的應用程序路徑是區分大小寫的。

5.需要讓所有機器的MachineKey相同.在Machine.Config中配置:

<machineKey
validationKey="1234567890123456789012345678901234567890AAAAAAAAAA"
decryptionKey="123456789012345678901234567890123456789012345678"
validation="SHA1"
decryption="Auto"
/>

(3)Session:

1. 不能直接通過Session億恩科技服務器在ASP.NET和ASP之間共享Session. 請使用微軟提供的解決方案:

http://msdn.microsoft.com/zh-cn/library/aa479313.aspx

2. 在不同的應用程序或一個網站:(www.23lll.com)的不同虛擬目錄之間無法共享Session

3. Session的過期時間是滑動時間.

4. Session存儲.NET自帶的值類型性能最優. 存儲對象會降低性能.

(4)SessionID:

1.SessionID 還可以保存在URL上, 設置Web.Config文件中的System.Web/sessionState節點的Cookiesless屬性即可:

<sessionState
cookieless="UseUri"
/>

2. 一般在Session超時或刪除之后,SessionID保持不變. 因為Session過期后會在億恩科技服務器端清除數據, 但是SessionID保存在用戶瀏覽器上, 所以只要瀏覽器不關閉則HTTP頭中的SessionID保持不變.

3.關閉瀏覽器后再訪問, SessionID會不同.

4.每打開一個IE6窗口, SessionID都不同, 在IE6中兩個窗口的Session不能共享.

5.FireFox的標簽頁和新的FireFox窗口, SessionID都相同, 在FF的窗口和標簽頁上Session能共享.

6.對于包含FrameSet的頁面,比如:

<frameset cols="25%,50%,25%">
<frame src="SessionID.aspx">
<frame src="SessionID.aspx">
<frame src="SessionID.aspx">
</frameset>

如果后綴名是.htm并且.htm文件沒有交給ASP.NET的ISAPI處理, 那么根據億恩科技服務器速度在每個Frame頁面生成不同的SessionID, 再刷新后相同都等于最后一個SessionID.

解決辦法是將.htm后綴改成.aspx, 或者將.htm文件交給ASP.NET的ISAPI處理.

(5)Session_End事件:

1. Session_End僅在InProc模式中可用

2. 關閉瀏覽器,Session_End是不會觸發的。HTTP是一種無狀態協議,億恩科技服務器沒有辦法知道你的瀏覽器是否已經關閉。

3. 當Session因為時間過期或調用Session.Abandon時,Session_End才會觸發.Session.Clear()僅僅是清除數據,但沒有刪除session。

4. Session_End由一個后臺線程觸發,使用工作者進程賬號運行. 所以程序不會通知發生的錯誤.

5. 在Session_End訪問數據庫要考慮權限問題. Session_End是用運行工作者進程(aspnet_wp.exe)的帳號運行的,這個賬號可以在machine.config中指定。因此,在Session_End中,如果使用integrity security連接SQL,它將使用工作者進程賬號身份連接,這可能會引起登錄失敗.

6.因為Session_End是有獨立線程出發的, 所以在Session_End中無法使用HttpContext對象(Request,Response,Server等對象都在HttpContext中), 即無法使用 Response.Redirect 和Server.Transfer等方法.

七.總結

我已經使用SqlServer模式對公司的多臺億恩科技服務器實現了Session共享, 億恩科技服務器重啟也不會導致用戶預定過程重新開始(預定過程需要的Session不會丟失). 希望本文對具體的Session億恩科技服務器搭建人員有所幫助.


本文出自:億恩科技【www.23lll.com】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    九色成人免费视频_久久一区视频_视频一区国产精品_精品视频在线观看
    久久久久久久久久久久久女国产乱| 欧美另类视频| 日韩一二三区视频| 亚洲国产91| 欧美在线观看www| 午夜精品影院| 午夜精品免费| 午夜精品www| 亚洲欧美亚洲| 亚洲午夜久久久久久久久电影网| 亚洲成在线观看| 欧美一区二区黄| 亚洲永久免费观看| 亚洲综合精品自拍| 亚洲一区二区视频| 亚洲综合色视频| 亚洲欧美中文在线视频| 亚洲综合第一| 午夜久久资源| 欧美中文在线观看| 亚洲大胆av| 亚洲精品欧美日韩专区| 亚洲精品日韩在线| aa国产精品| 亚洲桃色在线一区| 午夜精品视频| 久久国产精彩视频| 久久一区激情| 欧美高清在线视频观看不卡| 欧美精品观看| 欧美午夜视频| 国产乱码精品一区二区三区忘忧草 | 亚洲区免费影片| 亚洲三级电影在线观看| av成人免费在线| 亚洲一区网站| 久久精品国产99| 亚洲精品一区在线观看| 在线亚洲欧美视频| 午夜国产精品影院在线观看| 欧美一区二区女人| 亚洲丰满在线| 日韩午夜激情电影| 亚洲综合99| 久久久久久久一区| 欧美极品一区二区三区| 国产精品jvid在线观看蜜臀| 国产欧美一区二区三区久久| 精久久久久久| 亚洲免费精彩视频| 午夜精品成人在线| 亚洲美女在线看| 亚洲欧美日韩精品一区二区 | 欧美亚洲第一区| 国产一区二区三区成人欧美日韩在线观看 | 亚洲综合丁香| 开心色5月久久精品| 欧美日韩伊人| 狠狠操狠狠色综合网| 亚洲免费成人av| 亚洲欧美日韩综合| 亚洲美女视频在线观看| 欧美中文字幕视频| 欧美日本免费一区二区三区| 国产视频精品va久久久久久| 亚洲韩国一区二区三区| 亚洲欧美久久久| 日韩视频三区| 久久久久久网站| 欧美日韩亚洲国产一区| 韩日欧美一区| 亚洲一区二区视频| 99精品热6080yy久久 | 国产精品久久久久久模特 | 亚洲精品国产精品国产自| 亚洲欧美福利一区二区| 日韩小视频在线观看| 久久精品国产久精国产爱| 欧美日韩国产高清| 精品91在线| 午夜精品久久久久久久久久久 | 欧美高清在线一区| 国产亚洲电影| 亚洲视频一区在线观看| 亚洲欧洲日产国产网站| 欧美中文字幕视频在线观看| 欧美三日本三级三级在线播放| 精品电影在线观看| 午夜精彩国产免费不卡不顿大片| 中日韩男男gay无套| 欧美chengren| 狠狠88综合久久久久综合网| 亚洲一区三区在线观看| 亚洲天堂男人| 欧美精品一区二区三区蜜臀| 一区二区在线免费观看| 香蕉成人伊视频在线观看| 亚洲欧美日韩成人| 欧美日韩午夜| 亚洲免费观看在线观看| 99视频在线精品国自产拍免费观看| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品亚洲产品| 亚洲一区二区三区涩| 亚洲图片自拍偷拍| 欧美日韩精品二区| 日韩视频精品| 一区二区三区日韩欧美| 欧美精品激情blacked18| 亚洲第一黄网| 亚洲国产精品黑人久久久| 久久久久高清| 国产私拍一区| 欧美一二三视频| 久久成年人视频| 国产日韩欧美一区在线| 亚洲欧美一区二区在线观看| 午夜精品一区二区三区在线| 国产精品狠色婷| 亚洲午夜国产成人av电影男同| 亚洲深夜福利在线| 欧美日韩午夜| 中文国产成人精品| 亚洲欧美成人| 国产精品久久久久久久久久久久| 亚洲午夜国产一区99re久久| 亚洲欧美日韩国产中文| 国产精品福利片| 午夜日韩在线| 久久资源在线| 亚洲第一精品电影| 日韩写真在线| 国产精品成人国产乱一区| 亚洲天堂av电影| 欧美在线视频二区| 国内在线观看一区二区三区 | 欧美黄色aa电影| 亚洲精品黄网在线观看| 99在线|亚洲一区二区| 欧美日韩小视频| 亚洲午夜在线视频| 欧美一区二区三区精品电影| 国产午夜久久久久| 亚洲高清在线观看| 欧美激情一区二区三区成人| 日韩视频在线你懂得| 亚洲男人的天堂在线aⅴ视频| 国产精品亚洲美女av网站| 欧美一区二区三区的| 久久综合影视| 亚洲美女一区| 午夜亚洲视频| 伊人久久综合| 在线视频亚洲| 国产日韩一区二区三区在线| 亚洲高清123| 欧美日韩一区二区精品| 亚洲综合三区| 免费永久网站黄欧美| 99av国产精品欲麻豆| 欧美在线视频日韩| 亚洲国产精品成人精品| 亚洲性图久久| 国产夜色精品一区二区av| 亚洲精品国精品久久99热一| 欧美深夜影院| 久久大逼视频| 欧美区高清在线| 亚洲欧美日本国产有色| 欧美成人精品在线| 亚洲桃色在线一区| 免费观看国产成人| 欧美乱妇高清无乱码| 亚洲性感激情| 男男成人高潮片免费网站| 一级成人国产| 久久久人成影片一区二区三区| 亚洲精品一区久久久久久| 欧美在线一二三| 亚洲欧洲在线观看| 欧美在线观看天堂一区二区三区| 亚洲国产精品尤物yw在线观看| 午夜精品区一区二区三| 亚洲人成在线播放| 久久久欧美一区二区| 99热免费精品在线观看| 久久手机精品视频| 亚洲视频日本| 欧美国产日韩二区| 欧美一区久久| 国产精品igao视频网网址不卡日韩| 亚洲电影免费在线| 国产精品私拍pans大尺度在线| 亚洲精品在线免费观看视频| 国产午夜精品一区理论片飘花 | 欧美视频中文在线看| 亚洲激情视频网| 国产精品自拍在线| 中文日韩在线| 亚洲第一区中文99精品|