0133 用Redis存储Tomcat集群的Session
来源:互联网 发布:mysql from 多表 编辑:程序博客网 时间:2024/05/17 18:27
前段时间,我花了不少时间来寻求一种方法,把新开发的代码推送到到生产系统中部署,生产系统要能够零宕机、对使用用户零影响。
我的设想是使用集群来搞定,通过通知负载均衡Nginx,取下集群中的Tomcat节点,然后对Tomcat上的应用进行升级,再通知负载均衡Nginx,把Tomcat节点重新加载上去。依次这么做,把集群中的所有Tomcat都替换一次即可。
那么问题来了,在取下Tomcat节点和加载新Tomcat节点时如何做到对用户无影响呢?方法很简单,共享Session。
下面,我们用实例来说明此方案。我们的例子使用了一台Nginx做负载均衡,后端挂接了两台Tomcat,且每台Tomcat的Session会话都保存到Redis数据库中。其中,Nginx配置为non-sticky运行模式,也即每一个请求都可以被分配到集群中的任何节点。当要上线新代码时,只需简单地取下Tomcat实例,此时所有的访问用户会被路由到活动的Tomcat实例中去,而且由于会话数据都是保存在Redis数据库中,所以活跃用户并不会受影响。当Tomcat更新完毕,又可以把此节点加入到Nginx中。
安装Nginx
- # sudo rpm -ivh nginx-1.4.2-1.el6.ngx.x86_64.rpm
修改配置文件/etc/nginx/nginx.conf,并添加下面的内容:
- http {
- upstream tomcat {
- server localhost:8080;
- server localhost:8081;
- }
- include /etc/nginx/mime.types;
- default_type application/octet-stream;
- location / {
- proxy_pass http://tomcat;
- }
重启Nginx
- # sudo service nginx restart
接着,下载并安装Redis。步骤省略,很简单。
最后,我们需要配置Tomcat,让Tomcat把会话Session保存到Redis数据库。
我们要使用tomcat-redis-session-manager这样的第三方库,主页见:
https://github.com/jcoleman/tomcat-redis-session-manager
要注意此库并非开箱即用的,使用时需要做一些调整。你需要下载源码,并在更新了依赖库的版本后,重建项目。比如我使用了commons-pool2-2.2.jar和jedis-2.6.1.jar依赖库。要记住把这些jar文件复制到每一个Tomcat实例的lib子目录下。
在更新了commons-pool、jedis和tomcat版本这些库后,你可以使用build.gradle来构建整个项目。构建完毕后,复制新生成的tomcat-redis-session-manager-1.2.jar到每一个Tomcat实例的lib子目录下。并在修改每一个Tomcat实例的context.xml配置文件:
- <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
- <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
- host="localhost"
- port="6379"
- database="0"
- maxInactiveInterval="60" />
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 0133 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session实现session共享
- Redis存储Tomcat集群的Session
- Redis存储Tomcat集群的Session
- vc2008编译libjpeg
- shell编程(四)引号
- ReactJs 样式类的使用
- mongo3在Mac上安装
- 页面获取不到session中值
- 0133 用Redis存储Tomcat集群的Session
- HMaster不能被启动
- IE不支持getElementsByClassName最终完美解决方案
- 杂谈-个人博客的建设 和 网页版简历的完成
- 对与tableViewCell在进行多行删除编辑时,选中状态不出现时解决方案
- 知无涯之std::sort源码剖析
- java 网络编程之ServerSocket详解
- VMware安装失败 “Failed to create the requested registry key Key:installer Error:1021"
- Java中extends与implement 区别