一:Session简介
Session是什么呢?简单来说就是服务器给客户端的一个编号。当一台web服务器运行时,可能有若干个用户浏览正在运正在这台服务器上的网站。当每个用户首次与这台web服务器建立连接时,他就与这个服务器建立了一个Session,同时服务器会自动为其分配一个SessionID,用以标识这个用户的唯一身份。这个SessionID是由web服务器随机产生的一个由24个字符组成的字符串,我们会在下面的实验中见到它的实际样子。
二:Asp.Net中Session的集中模式和配置
(1):InProc,Session存储在进程内,这也是ASP.Net中的存储方式,也是默认值
(2): StateServer,Session存储在独立的状态服务即ASP.NET State Service中
(3):SQLServer,Session存储在SQL Server数据库中
(4):Custom,自定义保存方式,可以保存在Oracle、SQLServer、MongoDb、Redis中
本片文章主要讲述Session在Redis中的存储和共享
三:基于Redis的Session Provider配置
(1)分别对站点A和B的HomeController做如下更改,如下图所示,增加了创建Session和获取Session功能
分别对应的View视图
(2)RedisProvider配置:Microsoft.Web.RedisSessionStateProvider
用Nuget安装Microsoft.Web.RedisSessionStateProvider,如下图:
修改配置文件:
Redis的安装请参见:《Redis在Linux环境上的安装和启动》
四:负载均衡Session测试
(1)浏览器中输入:http://192.168.152.128/ 创建Session
(2)浏览器中输入:http://192.168.152.128/home/getsessionvalue, 打开两个Tab,一定要在同一个浏览器窗口中打开,否则SessionID肯定是不一样
从图中可以看到站点A共享站点B创建的Session。
从redis中也可以看出刚刚创建的Session,如下图
.net api 使用session ,重写HttpApplication的init方法
/// <summary> /// 打开session /// </summary> public override void Init() { this.PostAuthenticateRequest += (sender, e) => HttpContext.Current.SetSessionStateBehavior(SessionStateBehavior.Required); base.Init(); }