nginx+tomcat+redis完成session共享

原创 2015年08月28日 10:39:36

本文记录nginx+redis+tomcat实现session共享的过程

nginx安装:http://blog.csdn.net/grhlove123/article/details/47834673

redis安装:http://blog.csdn.net/grhlove123/article/details/47783471

准备两个tomcat,修改相应的端口


名称 IP 端口 tomcat版本 JDK
tomcat1 10.10.49.23 8080 7.0.40 1.7.0_25
tomcat2 10.10.49.15 8081 7.0.40 1.7.0_25

修改nginx.conf加上:

    upstream backend {
        server 10.10.49.23:8080 max_fails=1 fail_timeout=10s;
        server 10.10.49.15:8081 max_fails=1 fail_timeout=10s;
    }
修改nginx.conf的location成
    location / {
        root   html;
        index  index.html index.htm;
        proxy_pass http://backend;
     }

启动nginx。

下载tomcat-redis-session-manager相应的jar包,主要有三个:

wget https://github.com/downloads/jcoleman/tomcat-redis-session-manager/tomcat-redis-session-manager-1.2-tomcat-7-java-7.jar
wget http://central.maven.org/maven2/redis/clients/jedis/2.5.2/jedis-2.5.2.jar
wget http://central.maven.org/maven2/org/apache/commons/commons-pool2/2.0/commons-pool2-2.0.jar

下载完成后拷贝到$TOMCAT_HOME/lib中

修改两tomcat的context.xml:

<Context>

    <!-- Default set of monitored resources -->
    <WatchedResource>WEB-INF/web.xml</WatchedResource>

    <!-- Uncomment this to disable session persistence across Tomcat restarts -->
    <!--
    <Manager pathname="" />
    -->

    <!-- Uncomment this to enable Comet connection tacking (provides events
         on session expiration as well as webapp lifecycle) -->
    <!--
    <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" />
    -->

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

在tomcat/webapps/test放一个index.jsp

<%@ page language="java" %>
<html>
  <head><title>TomcatA</title></head>
  <body>
 
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>
sessionID:<%=session.getId()%> 
<br> 
SessionIP:<%=request.getServerName()%> 
<br> 
SessionPort:<%=request.getServerPort()%> 
<% 
//为了区分,第二个可以是222
out.println("This is Tomcat Server 1111"); 
%>  

启动tomcat,发现有异常:com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve 类找不到

分别打开三个jar包,确实没有这个类,解决可以参考:

http://blog.csdn.net/qinxcb/article/details/42041023


通过访问http://10.10.49.20/test/


刷新:

可以看到虽然Server从1111变为2222,但session的创建时间没有变化,这就完成了session共享。

用Redis存储Tomcat集群的Session

用Redis存储Tomcat集群的Session作者:chszs,转载需注明。博客主页:http://blog.csdn.net/chszs前段时间,我花了不少时间来寻求一种方法,把新开发的代码推送到...
  • chszs
  • chszs
  • 2015年01月11日 12:58
  • 99463

分布式集群Session共享 简单多tomcat8+redis的session共享实现

什么是Session         用户使用网站的服务,基本上需要浏览器与Web服务器的多次交互。HTTP协议本身是无状态的,需要基于HTTP协议支持会话状态的机制。这样的机制应该可以使Web服...
  • Jerome_s
  • Jerome_s
  • 2016年09月25日 11:10
  • 18189

使用Redis存储Nginx+Tomcat负载均衡集群的Session

环境:Cent OS 7.0(虚拟机环境)、Nginx 1.9.8、Redis 3.2.1一、背景在使用Nginx+Tomcat实现负载均衡的时候,由于Nginx对不同的请求分发到某一个Tomcat,...
  • u010870518
  • u010870518
  • 2016年07月25日 17:26
  • 20611

搭建Tomcat集群&通过Redis缓存共享session的一种流行方案

为什么要共享session? 我们使用单台Tomcat的时候不会有共享sesssion的疑虑,只要使用Tomcat的默认配置即可,session即可存储在Tomcat上。 ...
  • u011674124
  • u011674124
  • 2017年05月31日 12:17
  • 1089

tomcat redis session共享

  • 2017年02月23日 11:46
  • 240KB
  • 下载

tomcat redis session共享遇到的问题

最近在使用nginx做集群,当然集群相关就要处理session共享问题,于是尝试了使用redis来存储session来达到共享session的目的,但是其中也遇到很多问题,这里简单的记录下。 1....
  • jin5203344
  • jin5203344
  • 2016年08月17日 09:22
  • 1835

tomcat+nginx+redis实现均衡负载、session共享(二)

转自:http://www.cnblogs.com/zhrxidian/p/5491285.html 今天我们接着说上次还没完成session共享的部分,还没看过上一篇的朋友可以先看下上次内容,ht...
  • zoucui
  • zoucui
  • 2017年02月10日 16:00
  • 568

tomcat7 redis session 共享

tomcat7 redis session 共享 下载JDK7、tomcat7以备后续测试; 一、下载tomcat-redis-session的源码自行打包:https://github.com...
  • yucaifu1989
  • yucaifu1989
  • 2016年10月19日 17:05
  • 503

基于Redis的Tomcat集群Session共享

目前的web应用集群,使用Nginx做负载均衡,将upstream配置成ip_hash的方式,这种模式下,Nginx会根据来源IP和后端配置来做hash分配,确保固定IP只访问一个后端。 ...
  • qq_27376871
  • qq_27376871
  • 2016年09月20日 16:31
  • 1332

tomcat7 redis session 共享

针对之前的nginx+tomcat的负载均衡机制,因为会出现session丢失的问题,特研究了下redis的session共享;(如果想搭建本环境可从上一篇开始,涉及到nginx的环境搭建http:/...
  • qq584852076
  • qq584852076
  • 2015年06月15日 13:26
  • 20958
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:nginx+tomcat+redis完成session共享
举报原因:
原因补充:

(最多只允许输入30个字)