您的位置:首页 > 数据库 > Redis

Redis+Nginx+Tomcat实现Session共享

2016-03-17 15:40 603 查看

资源下载

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将改变

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  tomcat redis nginx session