使用Tomcat+Redis来实现集群部署中的Session共享问题

一、工作中因为要使用到Tomcat集群部署,此时就涉及到了Session共享问题,主要有三种解决方案:

1、使用数据库来存储Session

2、使用Cookie来存储Session

3、使用Redis来存储Sesssion

二、本文中主要讲一下第3种方案,也就是使用Redis来存储Session,Github中已经有该开源组件(tomcat-redis-session-manager),下面讲一下配置的步骤

1、配置tomcat配置文件context.xml


<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />        
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" 
    host="localhost"             <!-- Redis地址 -->
    port="6379"                  <!-- Redis端口 -->
    password="123456"            <!-- Redis密码 -->
    database="0"                 <!-- 存储Session的Redis库编号 -->
    maxInactiveInterval="60"     <!-- Session失效的间隔(秒) -->
    />

注:
1)Manager节点中的className属性为必选项,其它均为可选项

2)maxInactiveInterval设置不生效,暂时找不到原因,在部署中发现Session失效的间隔一直都是读取tomcat/conf/web.xml中的session-config节点中配置的session-timeout属性值,且都是以秒为单位(如有知道问题原因所在的,麻烦告诉我一声,非常感谢)

2、添加相关的jar包到tomcat/lib目录下,需要的jar包如下:

commons-pool2-2.2.jar
jedis-2.5.2.jar
tomcat-redis-session-manage-tomcat7.jar

注:

1)我将这些jar包上传到了百度云盘中,有需要的可以点击下载:http://pan.baidu.com/s/1bokMOVH

3、在nginx中配置负载均衡,配置文件为nginx.conf

http {
  upstream myServer {
    server 192.168.1.2:8080;
    server 192.168.1.3:8080;
  }
  server {
    listen 80;
    server_name www.kolbe.cn;
    location / {
      proxy_pass http://myServer;
    }
}

配置完后,访问www.kolbe.cn的请求都将被转发到192.168.1.2:8080以及192.168.1.3:8080中去,可以在页面中打印一下Session Id验证一下

Session Id : <%= request.getSession().getId() %>

当然,也可以到Redis库中直接查看.

注:

1)GitHub中该开源组件(tomcat-redis-session-manager)的主页:https://github.com/jcoleman/tomcat-redis-session-manager

2)该组件目前不支持Tomcat8,我用的是Tomcat 7.0.68版本


3)在程序中将对象放到Redis里时,该对象必须实现java.io.Serializable接口,否则将报错,如果对象中有其它对象的引用,该引用对象也需实现java.io.Serializable接口,所以在使用request.getSession().setAttribute()方法时,一定要注意一下这一个细节

转自:http://my.oschina.net/kolbe/blog/618167

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值