sessionState~RedisSessionStateProvider高可用的实现

早在几年前就有了sessionState进行共享session的方式,今天总结一下高可用redis实现的共享session的方式

sentinel集群搭建

1

工作过程图

2

配置

Redis数据服务配置

首先配置Redis的主从服务器,修改redis.conf文件如下
主服务配置

bind 192.168.xx.xx 192.168.xx.xx192.168.xx.xx
requirepass "123456"

从服务配置

bind 192.168.xx.xx 192.168.xx.xx192.168.xx.xx
requirepass "123456"
slaveof 192.168.xx.xx6379
masterauth 123456

Redis 哨兵服务配置

配置3个哨兵,每个哨兵的配置都是一样的。在Redis安装目录下有一个sentinel.conf文件,copy一份进行修改。

# 禁止保护模式
protected-mode no
# 配置监听的主服务器,这里sentinel monitor代表监控,mymaster代表服务器的名称,可以自定义,192.168.11.128代表监控的主服务器,6379代表端口,2代表只有两个或两个以上的哨兵认为主服务器不可用的时候,才会进行failover操作。
sentinel monitor mymaster 192.168.xx.xx 6379 2
# sentinel author-pass定义服务的密码,mymaster是服务名称,123456是Redis服务器密码
sentinel auth-pass mymaster 123456

启动

从主-再从-再哨兵

./redis-server ./redis.conf &
./redis-sentinel ./sentinel.conf &

哨兵集群操作命令

redis-cli -h 192.168.60.128 -p 26379 info sentinel
redis-cli -h 192.168.60.128 -p 26379 SENTINEL master mymaster
redis-cli -h 192.168.60.129 -p 26379 SENTINEL slaves1 mymaster
redis-cli -h 192.168.60.130 -p 26379 SENTINEL slaves2 mymaster

.net应用的配置

直接把redis数据服务器地址写上即可

当主redis宕机之后,会有几秒的停顿,然后会自动选举新的master.

<system.web>
    <compilation debug="true" targetFramework="4.5" />
    <httpRuntime targetFramework="4.5" />
    <sessionState mode="Custom" customProvider="MySessionStateStore" cookieName="pkulaw_v6_sessionid" timeout="240">
      <providers>
        <add name="MySessionStateStore" type="Microsoft.Web.Redis.RedisSessionStateProvider" connectionString="192.168.xx.xx:xx,192.168.xx.xx:xx,192.168.xx.xx:xx,password=xxx" databaseId="0" applicationName="xxx" connectionTimeoutInMilliseconds="30000" operationTimeoutInMilliseconds="20000" accessKey="" ssl="false" />
      </providers>
    </sessionState>
  </system.web>
posted @ 2020-12-29 14:32  张占岭  阅读(596)  评论(0编辑  收藏  举报