原文地址: http://blog.jboost.cn/session-redis.htmlhtml
一些项目初期出于简单快速,都是作单机开发与部署,可是随着业务的扩展或对可用性要求的提升,单机环境已不知足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是session的共享(若是一开始就是基于token的认证则可忽略)。本文介绍一个基于redis的tomcat session管理开源项目:redission-tomcat,可无代码侵入式地快速实现session共享。
nginx
redisson是与jedis相似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于redis的tomcat session管理器项目,项目地址:https://github.com/redisson/redisson/tree/master/redisson-tomcat 。相比于其它实现,该项目的存储更为高效,写操做也更为优化。每个session参数是在调用HttpSession.setAttribute
时写入redis的,其它方案却通常是每次都将整个session进行序列化后写入。git
将redisson-all-3.11.0.jar,redisson-tomcat-8-3.11.0.jar(针对tomcat8,其它版本可在上述项目地址页面找到下载连接)两个jar包下载放到tomcat的lib目录下。github
在tomcat conf目录下的context.xml文件中添加以下配置redis
<Manager className="org.redisson.tomcat.RedissonSessionManager" configPath="${catalina.base}/conf/redisson.conf" readMode="MEMORY" updateMode="AFTER_REQUEST" broadcastSessionEvents="false"/>
其中json
setAttribute
方法保存到redis中;2. AFTER_REQUEST,在每次请求以后,将全部session属性保存至redis。默认为DEFAULT。{
"singleServerConfig":{
"idleConnectionTimeout":10000,
"connectTimeout":10000,
"timeout":3000,
"retryAttempts":3,
"retryInterval":1500,
"password":"123456",
"subscriptionsPerConnection":5,
"clientName":null,
"address": "redis://127.0.0.1:6379",
"subscriptionConnectionMinimumIdleSize":1,
"subscriptionConnectionPoolSize":50,
"connectionMinimumIdleSize":24,
"connectionPoolSize":64,
"database":0,
"dnsMonitoringInterval":5000
},
"threads":16,
"nettyThreads":32,
"codec":{
"class":"org.redisson.codec.FstCodec"
},
"transportMode":"NIO"
}
以上为单机模式redis环境配置,其中password,address修改成本身的值。若是是集群模式,则配置文件为tomcat
{
"sentinelServersConfig":{
"idleConnectionTimeout":10000,
"connectTimeout":10000,
"timeout":3000,
"retryAttempts":3,
"retryInterval":1500,
"failedSlaveReconnectionInterval":3000,
"failedSlaveCheckInterval":60000,
"password":null,
"subscriptionsPerConnection":5,
"clientName":null,
"loadBalancer":{
"class":"org.redisson.connection.balancer.RoundRobinLoadBalancer"
},
"subscriptionConnectionMinimumIdleSize":1,
"subscriptionConnectionPoolSize":50,
"slaveConnectionMinimumIdleSize":24,
"slaveConnectionPoolSize":64,
"masterConnectionMinimumIdleSize":24,
"masterConnectionPoolSize":64,
"readMode":"SLAVE",
"subscriptionMode":"SLAVE",
"sentinelAddresses":[
"redis://127.0.0.1:26379",
"redis://127.0.0.1:26389"
],
"masterName":"mymaster",
"database":0
},
"threads":16,
"nettyThreads":32,
"codec":{
"class":"org.redisson.codec.FstCodec"
},
"transportMode":"NIO"
}
咱们可使用nginx来实现负载均衡,参考配置 微信
upstream cnserver{
server 127.0.0.1:8080 weight=2 fail_timeout=10s max_fails=1;
server 127.0.0.1:8081 weight=2 fail_timeout=10s max_fails=1;
}
server {
listen 80;
server_name localhost;
index index.html index.htm;
location /rest/ {
index index.html;
proxy_pass http://cnserver/rest/;
}
}
以上即为使用redisson-tomcat来实现单机部署到多机部署的全部配置。session
技术架构都是随着业务的发展而不断演进。在业务发展初期,用户量、业务复杂度都相对较低,为了实现快速上线验证,每每采用简单单一的架构。许多项目可能还没来得及进行架构演进升级就GG了,而有幸继续成长的项目必然会随着业务的扩张不断优化与升级。本文介绍的redisson-tomcat可帮助单机项目快速切换到多机支持,固然只是在session管理环节。若是涉及到其它如文件上传,定时任务等分布式支持,则要另作相应调整了。架构
个人我的博客地址:http://blog.jboost.cn
个人github地址:https://github.com/ronwxy
个人微信公众号:jboost-ksxy (一个不仅有实战干货的技术公众号, 欢迎关注)
———————————————————————————————————————————————————————————————