多站點共享Session常見的作法有:
- 使用.net自動的狀態服務(Asp.net State Service);
- 使用.net的Session數據庫;
- 使用Memcached。
- 使用Cookie方式實現多個站點間的共享(這種方式只限于幾個站點都在同一域名的情況下);
這里我們就 演練一下 以數據庫的形來存儲Session,來實現多站點共享Session。
首先我們 建好一下站點,如下圖:
Default.aspx
其中 有二個Button ,SetSession 主要是用于給一個 Session 賦值(如:Session["ShareValue"] = “abcd”
) ,
GetSession 主要就是獲得 一個 Session 值。
具體代碼如下:
代碼部分就這么多就行了…
下面就是要配置一下 Web.config了 , 其實主要就是在 <system.web>
這個節點中 增加 machineKey 及 sessionState 這兩個節點,
1.增加machineKey 主要作用是:
“按照MSDN的標準說法:“對密鑰進行配置,以便將其用于對 Forms 身份驗證 Cookie 數據和視圖狀態數據進行加密和解密,并將其用于對進程外會話狀態標識進行驗證。”也就是說Asp.Net的很多加密,都是依賴于machineKey里面 的值,例如Forms 身份驗證 Cookie、ViewState的加密。默認情況下,Asp.Net的配置是自己動態生成,如果單臺服務器當然沒問題,但是如果多臺服務器負載均 衡,machineKey還采用動態生成的方式,每臺服務器上的machinekey值不一致,就導致加密出來的結果也不一致,不能共享驗證和 ViewState,所以對于多臺服務器負載均衡的情況,一定要在每臺站點配置相同的machineKey。“ ,具體可以查一下其它資料。
2.增加 sessionState 主要是讓 Session 保存在數據庫中。
具體配置如下:
<sessionState mode="SQLServer" sqlConnectionString="Data Source=PC-07195;Initial Catalog=AWBUISession;Persist Security Info=True;User ID=jins;Password=js@#$1234" allowCustomSqlDatabase="true" cookieless="false" timeout="100"/>
數據庫配置:
使用aspnet_regsql.exe工具
ASP.NET 2.0版本后微軟提供了aspnet_regsql.exe工具可以方便的配置Session數據庫.該工具位于 Web 服務器上的"系統根目錄\Microsoft.NET\Framework\版本號"文件夾中.
使用舉例:
表示數據庫實例名稱. 可以用"."表示本機.
-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 選項包括自定義數據庫的名稱。 |
我的設置是:aspnet_regsql.exe -S . - E -d AWBUISession -ssadd -sstype c
好了。基本的 我們就已經搞定了。。
我們把 其中一個 服務器中的 defaut.aspx 中 “服務器 1” 改成 “服務器 2” ,這樣做的主要目地是 做一下 區別!
具體如下:
兩個網站的 URL分別是:
server 1:127.0.0.1:8081;
server 2:127.0.0.1:8080;
OK。下面我們就是 配置 Nignx了。
做如上的 設置:
OK。 nginx 這樣配置 就算OK 了。 我們啟動一下 nginx ..
在瀏覽器中 輸入我們 在 nginx 中配置的 URL 如:127.0.0.1:8090
@appName tAppName,
@appId int OUTPUT
AS
SET @appName = 'Test' --LOWER(@appName) 修改這里,使多個站點的APPname ,為一個固定值。
SET @appId = NULL
SELECT @appId = AppId
FROM [AWBUISession].dbo.ASPStateTempApplications
WHERE AppName = @appName
IF @appId IS NULL BEGIN
BEGIN TRAN
SELECT @appId = AppId
FROM [AWBUISession].dbo.ASPStateTempApplications WITH (TABLOCKX)
WHERE AppName = @appName
IF @appId IS NULL
BEGIN
EXEC GetHashCode @appName, @appId OUTPUT
INSERT [AWBUISession].dbo.ASPStateTempApplications
VALUES
(@appId, @appName)
IF @@ERROR = 2627
BEGIN
DECLARE @dupApp tAppName
SELECT @dupApp = RTRIM(AppName)
FROM [AWBUISession].dbo.ASPStateTempApplications
WHERE AppId = @appId
RAISERROR('SQL session state fatal error: hash-code collision between applications ''%s'' and ''%s''. Please rename the 1st application to resolve the problem.', 18, 1, @appName, @dupApp)
END
END
COMMIT
END
RETURN 0
重啟一下各站點。再在瀏覽一下網站點 “SetSession”, 再點:“GetSession” 這樣 我們就看到 服務器2 給出了我們 剛才在 服務器 1 中設置 的會話值了。
原文出自: