内容简介:一些项目初期出于简单快速,都是做单机开发与部署,但是随着业务的扩展或对可用性要求的提高,单机环境已不满足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是session的共享(如果一开始就是基于token的认证则可忽略)。本文介绍一个基于redis的tomcat session管理开源项目:redission-tomcat,可无代码侵入式地快速实现session共享。redisson是与jedis类似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于
一些项目初期出于简单快速,都是做单机开发与部署,但是随着业务的扩展或对可用性要求的提高,单机环境已不满足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是session的共享(如果一开始就是基于token的认证则可忽略)。本文介绍一个基于 redis 的tomcat session管理开源项目:redission-tomcat,可无代码侵入式地快速实现session共享。
1. 简介
redisson是与jedis类似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于redis的tomcat session管理器项目,项目地址: https://github.com/redisson/redisson/tree/master/redisson-tomcat 。相比于其它实现,该项目的存储更为高效,写操作也更为优化。每一个session参数是在调用 HttpSession.setAttribute
时写入redis的,其它方案却一般是每次都将整个session进行序列化后写入。
2. 使用
-
将 redisson-all-3.11.0.jar , redisson-tomcat-8-3.11.0.jar (针对tomcat8,其它版本可在上述项目地址页面找到下载链接)两个jar包下载放到tomcat的lib目录下。
-
在tomcat conf目录下的context.xml文件中添加如下配置
<Manager className="org.redisson.tomcat.RedissonSessionManager" configPath="${catalina.base}/conf/redisson.conf" readMode="MEMORY" updateMode="AFTER_REQUEST" broadcastSessionEvents="false"/>
其中
setAttribute
- 在tomcat conf目录下新增配置文件redisson.conf,内容如下
{ "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修改为自己的值。如果是集群模式,则配置文件为
{ "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来实现单机部署到多机部署的所有配置。
3. 总结
技术架构都是随着业务的发展而不断演进。在业务发展初期,用户量、业务复杂度都相对较低,为了实现快速上线验证,往往采用简单单一的架构。许多项目可能还没来得及进行架构演进升级就GG了,而有幸继续成长的项目必然会随着业务的扩张不断优化与升级。本文介绍的redisson-tomcat可帮助单机项目快速切换到多机支持,当然只是在session管理环节。如果涉及到其它如文件上传,定时任务等分布式支持,则要另做相应调整了。
我的个人博客地址: http://blog.jboost.cn
我的github地址: https://github.com/ronwxy
我的微信公众号:jboost-ksxy (一个不只有实战干货的技术公众号, 欢迎关注)
———————————————————————————————————————————————————————————————
欢迎关注我的微信公众号,及时获取最新分享
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 单机 Go 服务部署参考
- 基于 Win10 单机部署 Kubernetes 应用
- 初识Kubernetes(K8s):从一个单机部署实现Java Web应用例子开始
- 单机服务器部署Nginx/Node/Nuxt/React/NG,常规优化,常规自启脚本
- 入门架构——单机高性能
- Solr单机版的搭建
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Mobilizing Web Sites
Layon, Kristofer / 2011-12 / 266.00元
Everyone has been talking about the mobile web in recent years, and more of us are browsing the web on smartphones and similar devices than ever before. But most of what we are viewing has not yet bee......一起来看看 《Mobilizing Web Sites》 这本书的介绍吧!