博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用Tomcat-redis-session-manager来实现Tomcat集群部署中的Session共享
阅读量:5959 次
发布时间:2019-06-19

本文共 2077 字,大约阅读时间需要 6 分钟。

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

  1、使用数据库来存储Session

  2、使用Cookie来存储Session

  3、使用Redis来存储Sesssion

  4、使用Tomcat的session复制

  5、使用Memcached来存储Session

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

  1、环境准备

    Tomcat7 下载地址:

    Tomcat-redis-session-manager 下载地址:

    本文使用的Nginx来做的Tomcat集群。

           Nginx安装参考:

    Redis安装参考:

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

   

  注:

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

  2)maxInactiveInterval设置不生效,暂时找不到原因,在部署中发现Session失效的间隔一直都是读取tomcat/conf/web.xml中的session-config节点中配置的session-timeout属性值,且都是以秒为单位,(这个地方maxInactiveInterval好像不起作用,和web.xml中配置的session-config优先级有关?)

  3、添加Tomcat-redis-session-manager的jar包到tomcat/lib目录下,需要的jar包如下:

    commons-pool2-2.2.jar

    jedis-2.5.2.jar
    tomcat-redis-session-manage-tomcat7.jar

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

  http {
   upstream myServer {
    server 192.168.1.2:8080;   server 192.168.1.3:8080;    }   server {
    listen 80;     server_name localhost;     location / {
    proxy_pass http://myServer;    } } }

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

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

   如果在同一个浏览器页面上不断刷新访问,SessionId的值不变化的话,说明配置正确,此时获取的是同一个Session对象。

   也可以通过redis客户端连接到Redis库中直接查看:查看会显示有 “56E2FAE376A47F1C0961D722326B8423” key的 session 数据,value为序列化数据。

  

  注:

  1)GitHub中该开源组件(Tomcat-redis-session-manager)的主页:

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

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

  4)因为要把Tomcat-redis-session-manager的jar包放到Tomcat/lib中,对Tomcat的部署造成了侵入,可以使用Spring Session来替代,spring-session使用拦截器重新包装了request从而替换session实现

  5)因为所有集群的Tomcat中配置的Redis地址是一个,如果Redis崩溃了,那么Session就不可用了,所以需要部署Redis集群,实现故障自动切换,高可用的目标。

  

 

文章参考自:

    1.https://my.oschina.net/kolbe/blog/618167

    2.http://www.cnblogs.com/lengfo/p/4260363.html

    

你可能感兴趣的文章
用XSLT和XML改进Struts
查看>>
WEB测试—功能测试
查看>>
在react或vue中,for循环用Index作为key值是好还是坏呢?
查看>>
2014.10.1 Form中显示pdf文件
查看>>
NERDTree 快捷键辑录
查看>>
Python数据分析Numpy库方法简介(一)
查看>>
javaWeb:相关监听方法汇总
查看>>
JSP 实现 之 读取数据库显示图片
查看>>
JS——特效秀
查看>>
Beta冲刺——day6
查看>>
前端:CheckBox事件函数js
查看>>
Comet OJ - Contest #3 题解
查看>>
[网络流24题-9]试题库问题
查看>>
jquery选择器详解
查看>>
C# 保留2位小数
查看>>
使用xshell远程连接Linux
查看>>
杭电ACM1007
查看>>
faster-RCNN台标检测
查看>>
Unix环境高级编程 centos中配置apue编译环境
查看>>
运算符
查看>>