使用tomcat-redis-session-manager实现session共享

https://blog.csdn.net/javandroid/article/details/52959105


测试环境:

- Version ip Port
nginx(可选)      
jdk 1.7.0_79    
tomcat1 7.0.70 127.0.0.1 8082
tomcat2 7.0.70 127.0.0.1 8083
redis 2.8.9 127.0.0.1 6379

1.获得tomcat-redis-session-manager.jar

①从github上下载tomcat-redis-session-manager-版本 的源码。 
②编译源码 
使用命令行切换到源码目录,使用命令gradle build编译。 
具体步骤请参考博客:http://blog.csdn.net/wanglipo/article/details/51669526

2.拷贝jar包到tomcat的lib目录下

tomcat-redis-session-manager.jar 
commons-pool2.jar 
jedis.jar 
将以上3个jar包拷贝到tomcat/lib下面。

3.在Tomcat中配置redis session管理器

在tomcat目录/conf/context.xml中配置如下(有几个tomcat参与管理session就要都配置)

<Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" />
<Manager className="com.radiadesign.catalina.session.RedisSessionManager"
         host="localhost"
         port="6379"
         database="0" -- optional: defaults to "0" -->
         maxInactiveInterval="60"  />
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

注意:上面的配置要注意路径。 
因为github上最新版已经将tomcat6和7,jdk6和7都兼容了,而以前则是分成不同工程。因此两者使用了不同的名称。 
新版本使用的是com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve 
旧版本使用的是com.radiadesign.catalina.session.RedisSessionHandlerValve 
【如果使用的话,直接使用新版本即可】

4.测试

注意: 
因为是在同一台pc上部署的两个tomcat,所以需要将tomcat端口改成不一样的。 
Tomcat1:

<Server port="8025" shutdown="SHUTDOWN">
<Connector connectionTimeout="20000" port="8082" protocol="HTTP/1.1" redirectPort="8443"/>
<Connector port="8029" protocol="AJP/1.3" redirectPort="8443"/>
  • 1
  • 2
  • 3

Tomcat2:

<Server port="8035" shutdown="SHUTDOWN">
<Connector connectionTimeout="20000" port="8083" protocol="HTTP/1.1" redirectPort="8443"/>
<Connector port="8039" protocol="AJP/1.3" redirectPort="8443"/>
  • 1
  • 2
  • 3

在两个tomcat中部署项目,这里简单处理如下。 
在tomcat1的webapps下新建www目录,并在www下新建index.jsp文件。 
文件内容如下:(如果是tomcat2则将”TomcatA”改为”TomcatB”)

<%@ pagelanguage="java" %>

<html>

    <head><title>TomcatAtitle>head>

    <body>
        <%
        out.println("This is TomcatA");
        %>

        <br>                
        sessionID:<%=session.getId()%>

        <br>
        SessionIP:<%=request.getServerName()%>

        <br>
        SessionPort:<%=request.getServerPort()%>

    body>

html>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

现在可以进行测试了。启动redis,启动tomcat1和tomcat2。分别访问http://localhost:8082/www/index.jsp和http://localhost:8083/www/index.jsp 
访问后浏览器结果如下: 
这里写图片描述 
这里写图片描述

测试结果说明: 
很显然,这两个浏览器输出来自不同的tomcat。但是其sessionID却是一样的,说明session共享成功。

最后使用redis客户端查看一下保存进redis的内容: 
这里写图片描述
说明使用redis来管理session时,将sessionID作为key保存在了redis。key的值发现是乱码,发现还有个TTL,自然就是过期时间了(刷新一下,该值在减小)。

再使用redis自带的客户端打开瞧瞧key的值,发现了熟悉的字样,出现了jar包目录相关的字符串,还有SessionSerialization(session序列化)。 
这里写图片描述

到此,使用redis来管理session的测试结束。当然了,我们还可以加个nginx来将请求分发到tomcat1和tomcat2,访问时就不需要用两个浏览器窗口来测试了,具体过程也不会太复杂,可以参考下面的博客。

文中用到的资源下载:context.xml、index.jsp和三个jar包

参考博客:基于nginx tomcat redis分布式web应用的session共享配置

相关问题: 
使用tomcat-redis-session-manager 有没有弊端?

版权声明:本文为博主原创文章,版权归博主所有。如转载,请注明出处! https://blog.csdn.net/javandroid/article/details/52959105

你可能感兴趣的:(spring)