资源下载
- tomcat-redis-session-manager:https://github.com/jcoleman/tomcat-redis-session-manager/downloads
- CentOS-6.5-64位下搭建jdk7 + mysql5.5 + tomcat7 + nginx环境搭建
- 搭建nginx + tomcat 集群,请查阅《Tomcat集群与Session共享 + Nginx负载》
- Redis搭建,请查阅《Centos6.5安装redis3.0.7》
- 本地下载: jedis-2.2.1.jar+commons-pool-1.6.jar+tomcat-redis-session-manager-1.2-tomcat-7.jar
实现
- 还原两个Tomcat下的conf/server.xml配置,尤其是以下节点中,不要加jvmRoute。
<Engine name="Catalina" defaultHost="localhost">
若加上jvmRoute,会导致redis内容占用过大,jvmRoute会被循环复制进redis中,导致内存爆满。如下图:
- 修改两个tomcat配置文件conf/context.xml
<Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" />
<Manager className="com.radiadesign.catalina.session.RedisSessionManager"
host="192.168.25.132"
port="6379"
database="0"
maxInactiveInterval="60" />
上述方式是整个Tomcat都采用redis保存Session,我们也可以使用在conf\Catalina\localhost下加入一个xml启动项目,此时是单独对该项目采用redis,如加入一个ROOT.xml,代码如下:
<?xml version='1.0' encoding='utf-8'?>
<Context path="/" docBase="F:\learn\tomcat\ewebsite" debug="0" privileged="true">
<Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" />
<Manager className="com.radiadesign.catalina.session.RedisSessionManager"
host="192.168.25.132"
port="6379"
database="0"
maxInactiveInterval="60" />
</Context>
- 在Tomcat的lib下加入对应的jar
测试
测试方式请参考《Tomcat集群与Session共享 + Nginx负载》
同时查看Redis中的keys,已将SessoionId保存,可以flushdb清空redis数据,SessoionId将改变