zoukankan      html  css  js  c++  java
  • .Net分布式架构(二):基于Redis的Session共享

    原文:.Net分布式架构(二):基于Redis的Session共享

    一: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,如下图

      

  • 相关阅读:
    eclipse新建maven web项目
    mongodb启用Profiling定位问题
    Linux下系统监控工具nmon使用
    MMS(mongodb监控工具)
    Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录
    mongodb sharding集群搭建
    linux 下mongodb 3.2.5单机版安装
    linux mongodb replica set集群安装
    DOS命令查询当前文件夹中文件数量
    centos7 开放mongodb端口
  • 原文地址:https://www.cnblogs.com/zhang1f/p/11953451.html
Copyright © 2011-2022 走看看