码迷,mamicode.com
首页 > 数据库 > 详细

SqlServer Session共享注意点

时间:2017-08-31 23:11:08      阅读:348      评论:0      收藏:0      [点我收藏+]

标签:str   use   targe   知识库   mysql   站点   ref   www.   ros   

公司下派任务,之前的网站是一台服务器,由于用户过多,负载过大,现在老大要求多加一台服务器。加就加贝,应该跟我这DEV没有

关系吧,应该不会碰到Source的吧。但是,之前网站有一些数据是放在Session里面的。大家应该理解Sessino的机制(自己的理解):当用户访问服务器的时候,会在Cookie里面留下一个SessionId,HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value就能取到,然后服务器会根据这个SessionId 来跟我服务器这边进行数据匹配,简单说就是拿你的SessionId来取存放在我服务器端的数据,类似于Key:Word。由于当一个客户端访问一个服务器,存放在Session的数据是在服务器端的,若是我加一台服务器的话,这Session的数据就要共享出来,能够让我两台机器同时访问到。这样,用户访问服务器的时候,我切换服务器机器就不会丢失Sesson里面的数据了。

  我遇到的问题:

  在网上搜了关于Session 共享的方法,http://www.cnblogs.com/xinhaijulan/archive/2010/08/21/1805116.html  有很多,我就选择一个SqlServer共享Sessin的方法。

  首先,你得建立这个Sqlserver数据库。cmd命令。C:\Windows\Microsoft.NET\Framework\v2.0.50727>aspnet_regsql.exe -S jpmsnmdb05t - E -d AWBUISession -ssadd -sstype c

  命令不懂的看我文中的链接。很简单。

  然后,在Asp.net 项目中的Web.config里面<system.web>输入

 

<machineKeyvalidationKey="1234567890123456789012345678901234567890AAAAAAAAAA"decryptionKey="123456789012345678901234567890123456789012345678"validation="SHA1"decryption="Auto"/>
<sessionStatemode="SQLServer"sqlConnectionString="server=jpmsnmdb05t; database=AWBUISession;Trusted_Connection=Yes; Persist Security Info=False;"allowCustomSqlDatabase="true"cookieless="false"timeout="100"/>

 

  到了这一步你在代码里面设置Session["name"]="value"的话,他就会将你的信息保存在SqlServer你建立的数据库中Session表中。

读取的话,我是这样设置的,从客户端获得SessionId,然后根据这个SessionId到表里面查询,查到的数据反编译出来就可以了,不懂得可以看看我的附件,我写了一个用户登录测试系统。

  当中我遇到了一个问题,就是我不会建立测试环境。光有两台机器。你要记住,SessionId是cookie信息,那么不同的domain(就是URL)他的SessionId是不同的,所以你要建立多个服务器共享一个session的话,一定要建立一个相同的domain。这样你就可以随心所欲访问那一台服务器了,举个例子:比如用户登录时访问了第一台服务器,登录好后,服务器切换到第二台服务器了,用户当然不知道,用户还在继续访问页面,系统肯定要检测一下是不是用户登录了,不然得让用户登录去,好,你得看看Session里面的信息吧,根据SessionId得到信息?若是domain不同,你的SessionId不同,现在你的SessionId已经不是之前的那个了,你肯定在怀恋你登录第一台服务器的SessionId。若是你设置同一个domain的话,好,你无论访问多少台机器,你的SessionId是一个,那么取出用户信息还不是小case。好,如何建立一个相同的domian:

  设置本地的host,本地host路径在哪?我问同事的,我也不是很清楚了,C:\Windows\System32\drivers\etc

  很简单,你知道你的服务器IP地址吧。那么只要修改你的host文件,看 

    172.23.126.137      SessionTest          # source server
      10.168.109.120      SessionTest         # x client host

  这是我添加的,两台服务器,同一个domain:SessionTest        

    由于我把系统发布到服务器IIS的时候设置的端口号是8078,所以我只要在本地访问http://sessiontest:8078/就好了。

    手动的开/关IIS里面的站点进行切换服务器。

   这样测试的环境也弄好啦。

    有个没有解决的问题,若是有读者涉及到也可以交流一下,在本地运行我的VS,访问页面,没有任何的问题,

若是把系统放到服务器上面,我发现,当我取Session信息的时候,存放Session数据库表中满足我页面搜索条件的只有一条,但是它却出现了两条,这两条SessionId,前一大半是一样的,跟HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value 是一样的。HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value这个值,居然跟我ASPStateTempSessions表里面的SessionId不一样。我的HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value只是ASPStateTempSessions表里面的SessionId的一半。看下图,

HttpContext.Current.Request.Cookies["ASP.NET_SessionId"].Value :x0if3uuddqmpl4451jberf2h

ASPStateTempSessions表里面的SessionId:x0if3uuddqmpl4451jberf2h077b2520

SqlServer Session共享注意点

标签:str   use   targe   知识库   mysql   站点   ref   www.   ros   

原文地址:http://www.cnblogs.com/littlewrong/p/7460730.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!