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

Tomcat集群之使用Redis来存储集群Session

2016-08-03 11:42 573 查看
在对tomcat进行集群时,不可避免的涉及到session的共享问题。session共享有这几种方案:

每个tomcat都保存所有的session,且需要有一定的机制来同步session

将session放在第三方,每个tomcat自己不再维护session,当tomcat需要使用session时,需要去第三方库读取。

本人使用jboss搭建过高可用的web环境,当时使用两台机器进行高可用环境的搭建,所以采用了第一种方案——每个jboss都维护所以的session,且会周期新的同步session。

同步session的方法优点是简单,缺点就是当有很多台机器进行session同步时,网络带宽和延迟很可能会造成session的同步失败。

因此,当搭建高并发的web环境时,通常会使用第二种方法,即由第三方来维护session。

由于session读取对速度要求比较高,因此在选择session存数方案时,尽量选择内存型数据库。常用的内存型数据库有memorycached和redis,后者由于某种原因,tomcat官方已不再推荐使用(memorycached和tomcat6集成没问题,和tomcat7集成时会报overide final method 错误)。因此这里使用tomcat7 + redis的方式来进行集群。

本文主要介绍如何使用redis来对tomcat7的session进行托管。

第一步,安装redis

windows还是linux,自行选择,安装过程这里不做赘述。

第二步,拷贝tomcat需要的jar

将如下几个jar拷贝到
${TOMCAT_HOME}/lib


tomcat-redis-session-manager-VERSION.jar


jedis-2.5.2.jar


commons-pool2-2.2.jar


第三步,配置tomcat

编辑
${TOMCAT_HOME}/conf/context.xml
,在context中加入

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="localhost"
port="6379"
database="0"

maxInactiveInterval="60" />


其中host和port为redis的ip和端口

至此配置完成,tomcat会使用redis来托管session。

经测试,只要redis不重启,用户session就不会丢失。

注意:放到redis中的对象必须为可序列化对象。因此,在编程过程中,放置的session对象必须实现serialiable接口。

虽然session保存到了redis中,但是如果redis挂掉,session也会丢失。为了解决此问题,可对redis进行集群。有兴趣的童鞋可以自己尝试一下。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  tomcat session redis 集群