成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

nginx負載均衡,多站點共享Session

運維 系統運維
多站點共享Session有很多方法,本文將演練一下以數據庫的形式存儲Session,來實現多站點共享Session。

  多站點共享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 保存在數據庫中。

  具體配置如下:

  1. <machineKey validationKey="86B6275BA31D3D713E41388692FCA68F7D20269411345AA1C17A7386DACC9C46E7CE5F97F556F3CF0A07159659E2706B77731779D2DA4B53BC47BFFD4FD48A54" 
  2.                 decryptionKey="9421E53E196BB56DB11B9C25197A2AD470638EFBC604AC74CD29DBBCF79D6046" 
  3.  
  4.    validation="SHA1" decryption="AES"/>   
  5.  
  6.  <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\版本號"文件夾中.

  使用舉例:

  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 參數說明:

  我的設置是:aspnet_regsql.exe -S . - E -d AWBUISession -ssadd -sstype c

  好了。基本的 我們就已經搞定了。。

  現在 我們分別把我們剛建的一個網站 部署 到 IIS 中。不過我們既然要負載。至少也的部署兩份。

  我們把 其中一個 服務器中的 defaut.aspx 中 “服務器 1” 改成 “服務器 2” ,這樣做的主要目地是 做一下 區別!

  具體如下:

  兩個網站的 URL分別是:

  server 1:127.0.0.1:8081;

  server 2:127.0.0.1:8080;

  OK。下面我們就是 配置 Nignx了。

  首先 在 nginx\conf 配置  文件中找到 nginx.conf 這個文件 ,就記事本打開,

  做如上的 設置:

  OK。  nginx  這樣配置 就算OK 了。 我們啟動一下 nginx ..

  在瀏覽器中 輸入我們 在 nginx 中配置的 URL 如:127.0.0.1:8090

  我們會看到 服務器 1 已經開始為我們服務了,我們再點一下 “SetSession”來設置一下一個 會話值,

  我們會看到 服務器 2 開始 工作。這時我們再點一下 “GetSesion”看一下 剛才在 服務器 1 設置 的會話值,結果如下 :

  出現這種情況 ,主要就是在數據庫中存儲 一個會話時 沒有做到 服務器1 和服務2的Session 共享,主要是在:

  ASPStateTempSessions 這個表中的 一個SessionID ,

  其中的SessionId包括兩個部分:網站生成的24位SessionID及8位AppName對于不同的站點,其AppName不同,在能夠在不同站點下使24位SessionID相同的情況下,要保證經過組合加上AppName后的SessionID相同,可以通過修改存儲過程TempGetAppID,使其得到的SessionID與AppName無關,修改TempGetAppID如下:

  1. ALTER PROCEDURE [dbo].[TempGetAppID]  
  2.  
  3.     @appName    tAppName,  
  4.  
  5.     @appId      int OUTPUT  
  6.  
  7.     AS  
  8.  
  9.     SET @appName = 'Test' --LOWER(@appName) 修改這里,使多個站點的APPname ,為一個固定值。  
  10.  
  11.     SET @appId = NULL 
  12.  
  13.    
  14.  
  15.     SELECT @appId = AppId 
  16.  
  17.     FROM [AWBUISession].dbo.ASPStateTempApplications  
  18.  
  19.     WHERE AppName = @appName   
  20.  
  21.     IF @appId IS NULL BEGIN  
  22.  
  23.         BEGIN TRAN    
  24.  
  25.         SELECT @appId = AppId 
  26.  
  27.         FROM [AWBUISession].dbo.ASPStateTempApplications WITH (TABLOCKX)  
  28.  
  29.         WHERE AppName = @appName         
  30.  
  31.         IF @appId IS NULL  
  32.  
  33.         BEGIN  
  34.  
  35.             EXEC GetHashCode @appName, @appId OUTPUT             
  36.  
  37.             INSERT [AWBUISession].dbo.ASPStateTempApplications  
  38.  
  39.             VALUES  
  40.  
  41.             (@appId, @appName)             
  42.  
  43.             IF @@ERROR = 2627 
  44.  
  45.             BEGIN  
  46.  
  47.                 DECLARE @dupApp tAppName             
  48.  
  49.                 SELECT @dupApp = RTRIM(AppName)  
  50.  
  51.                 FROM [AWBUISession].dbo.ASPStateTempApplications  
  52.  
  53.                 WHERE AppId = @appId  
  54.  
  55.                 RAISERROR('SQL session state fatal error: hash-code collision between applications ''%s'' and ''%s''. Please rename the 1st application to resolve the problem.',  
  56.  
  57.                             18, 1, @appName, @dupApp)  
  58.  
  59.             END  
  60.  
  61.         END  
  62.  
  63.         COMMIT  
  64.  
  65.     END  
  66.  
  67.     RETURN 0                         

  經過以上修改之后,下面要實現多個站點共用同一個SessionID.

  重啟一下各站點。再在瀏覽一下網站:

  點 “SetSession”,

  再點:“GetSession” ,

  可以看到  服務器1 和服務器 2 返回的是相同的結果,達到了 “多站點共享Session”

  附加一點: Session 過期刪除,主要是 在 SQL server 代理中的作業完成。

  具體的可以,查一下其它相關資料。

責任編輯:黃丹 來源: cnblogs.com
相關推薦

2010-03-24 10:35:02

Nginx負載均衡器

2012-07-31 09:25:42

nginx負載均衡反向代理

2013-04-22 11:29:14

Nginx

2017-12-13 15:33:02

LinuxNginxTomcat

2011-12-02 22:51:46

Nginx負載均衡

2010-05-06 15:24:35

Tomcat負載均衡

2010-05-05 22:51:24

2010-05-06 10:01:26

nginx負載均衡

2011-09-01 10:23:47

Nginx負載均衡器負載均衡

2010-05-07 12:23:23

nginx負載均衡

2011-01-07 11:14:17

Nginx負載均衡負載均衡

2014-07-28 11:37:49

NginxTomcat

2017-11-09 10:42:11

Nginx負載均衡策略

2024-11-11 09:51:46

Nginx部署負載

2019-09-18 10:39:08

負載均衡反向代理TCP

2010-03-25 18:52:15

Nginx負載均衡

2010-05-07 12:27:53

nginx負載均衡

2017-12-18 12:04:02

Nginx代理均衡

2019-06-24 15:58:53

TCPUDPNginx

2019-11-04 15:35:53

Nginx反向代理負載均衡
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品一区二区三区久久久 | 日本亚洲一区 | 在线观看黄视频 | 亚洲女优在线播放 | 久久久久久高清 | 一级欧美 | 红桃视频一区二区三区免费 | 中国美女撒尿txxxxx视频 | 中文字幕高清免费日韩视频在线 | 亚洲三区在线观看 | 日日操av| 日韩一二区 | 成年视频在线观看 | 久久性 | 国产激情一区二区三区 | 欧美日韩在线观看一区 | 中文字幕在线观看视频网站 | 国产一区二区电影 | 伦理午夜电影免费观看 | 美女久久 | 天天操操| 精品久久久久久久久久 | 国产真实精品久久二三区 | 亚洲视频在线免费 | 91国在线观看 | 欧美一区二区 | 午夜视频一区 | 成年人视频在线免费观看 | 91啪影院 | 色爱综合网 | 色一阁 | 亚洲网址 | 欧美日韩国产一区二区 | 国产小视频在线 | 美女黄网 | 美国一级黄色片 | 国产在视频一区二区三区吞精 | 日韩一区二区三区在线 | 高清免费av | 亚洲精品国产一区 | 日韩视频一级 |