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
编辑
其中host和port为redis的ip和端口
至此配置完成,tomcat会使用redis来托管session。
经测试,只要redis不重启,用户session就不会丢失。
注意:放到redis中的对象必须为可序列化对象。因此,在编程过程中,放置的session对象必须实现serialiable接口。
虽然session保存到了redis中,但是如果redis挂掉,session也会丢失。为了解决此问题,可对redis进行集群。有兴趣的童鞋可以自己尝试一下。
每个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进行集群。有兴趣的童鞋可以自己尝试一下。
相关文章推荐
- 用Redis存储Tomcat集群的Session
- 0133 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 使用Redis存储Nginx+Tomcat负载均衡集群的Session
- tomcat使用redis存储共享session
- 用Redis存储Tomcat集群的Session
- Nginx+Tomcat+Memcached 集群Session共享[memcached服务安装、tomcat使用memcache存储session、nginx安装配置实现tomcat负载均衡]
- tomcat集群使用redis实现session共享
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session实现session共享
- Tomcat7集群扩展session集中管理,tomcat-redis-session-manager使用
- Redis存储Tomcat集群的Session
- Tomcat 使用Redis存储Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 用Redis存储Tomcat集群的Session
- 使用Tomcat+Redis来实现集群部署中的Session共享问题
- Redis存储Tomcat集群的Session
- 使用Redis存储Nginx+Tomcat负载均衡集群的Session