http://luanzhz.blog.163.com/blog/static/58023129201101811445262/
在ASP.NET的程式中要使用Session物件時,必須確保頁面的@page指令中EnableSessionState屬性是True或者 Readonly,並且在web.config檔案中正確的設定了SessionState屬性。
ASP.NET中Session的狀態保持是由web.config檔案中的標記下的標記的mode屬性來決定的。該屬性有四種可能的 值:Off、Inproc、StateServer和SQlServer。
設為Off會禁用Session。
Inproc是預設的設定,這種模式和以前的ASP的會話狀態的方法是類似的,會話的狀態會被儲存在ASP.NET程式中,它的優點是顯而易見 的:效能。程式內的資料訪問自然會比跨程式的訪問快。然而,這種方法Session的狀態依賴於ASP.NET程式,當IIS程式崩潰或者正常重起啟時, 儲存在程式中的狀態將丟失。
為了克服Inproc模式的缺點,ASP.NET提供了兩種程式外保持會話狀態的方法。
ASP.NET首先提供了提供了一個Windows服務:ASPState,這個服務啟動後,ASP.NET應用程式可以將mode屬性設定為 “SateServer”,來使用這個Windows服務提供的狀態管理方法。
除了在web.config檔案中設定mode屬性為StateServer外,還必須設定執行StateServer伺服器的IP地址和埠 號.
1、如果在IIS所在的機器執行StateServer則IP地址就是127.0.0.1,埠號通常是42424.配置如下:
mode=”StateServer”
stateConnectionString="tcpip=127.0.0.1:42424"
<system.web> <compilation debug="true" targetFramework="4.0" /> <authentication mode="Forms"> <forms loginUrl="~/login.html" timeout="2880" /> </authentication> <sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424"/> </system.web>
2、找一臺伺服器作為Session伺服器(如IP為:192.168.1.244),啟動其Windows中的ASP.NET State Service(預設的埠號為42424),把啟動型別改為自動;
3、修改Session伺服器登錄檔中的項 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services \aspnet_state\Parameters中的AllowRemoteConnection 鍵的值為1,其中的Port鍵控制ASP.NET State Service的監聽埠;修改後需要重啟ASP.NET State Service才生效;
4、每臺伺服器的web。config 的 stateConnectionString都指向這臺伺服器
使用這種模式,會話狀態的儲存將不依賴IIS程式的失敗或者重啟,會話的狀態將儲存在StateServer程式的記憶體空間中。
另一種會話狀態模式是SQLServer模式。這種模式是將會話的狀態儲存在SQL Server資料庫中的。使用這種模式前,必須至少有一臺SQL Server伺服器,並在伺服器中建立需要的表和儲存過程。.NET SDK提供了兩個指令碼來簡化這個工作:InstallSqlState.sql和UnInstallSqlState.sql。這兩國檔案存放在下面路徑 中:
WinntMicrosoft.NETFramework
要配置SQL Server 伺服器,可以在命令列中執行SQL Server提供的命令列工具osql.exe
osql -s [server name] -u [user] -p [password]
例如:
osql -s (local) -u as -p “”-i InstallSqlState.sql
做好必要的資料庫準備工作後,將web.config檔案中的sessionstate元素的mode屬性改為”sqlserver”,並指定 SQL連線字串。具體如下:
mode="SQLServer"
sqlConnectionString="data source=127.0.0.1;userid=sa;password=;Trusted_Connection=yes"
使用SQLServer模式處了可以使Session的狀態不依賴於IIS伺服器之外,還可以利用SQL Server的叢集,使狀態儲存不依賴於單個的SQL Server,這樣就可以為應用程式提供極大的可靠性。