`

Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享

 
阅读更多

一、Session共享使用tomcat-cluster-redis-session-manager插件实现

插件地址见:https://github.com/ran-jit/tomcat-cluster-redis-session-manager

该插件支持Tomcat7、Tomcat8、Tomcat9

或者直接在附件中下载(版本为2.0.2,2017-11-27日前最新版本)

 

这里有是一个只支持Tomcat7的,不支持tomcat8,暂时不见新的维护:

https://github.com/jcoleman/tomcat-redis-session-manager

 

二、tomcat-cluster-redis-session-manager详解

1、解压后的文件如下:



 conf目录下有一个redis-data-cache.properties :Redis的配置文件

 

Java代码  收藏代码
  1. #-- Redis data-cache configuration  
  2.   
  3. #- redis hosts ex: 127.0.0.1:6379, 127.0.0.2:6379, 127.0.0.2:6380, ....  
  4. redis.hosts=127.0.0.1:6379  
  5.   
  6. #- redis password (for stand-alone mode)  
  7. #redis.password=  
  8.   
  9. #- set true to enable redis cluster mode  
  10. redis.cluster.enabled=false  
  11.   
  12. #- redis database (default 0)  
  13. #redis.database=0  
  14.   
  15. #- redis connection timeout (default 2000)  
  16. #redis.timeout=2000  

 

 

lib目录下有4个jar包,如下:

commons-logging-1.2.jar

commons-pool2-2.4.2.jar

jedis-2.9.0.jar

tomcat-cluster-redis-session-manager-2.0.1.jar

 

三、使用方法:

压缩文件中有使用方法,见readMe.txt 文件:

第一步:

 

Java代码  收藏代码
  1. 1. Move the downloaded jars to tomcat/lib directory  
  2.         * tomcat/lib/  

 就是把lib目录下的Jar包全复制到tomcat/lib目录下

 

(一般来说tomcat是集群,至少有2个tomcat,所以先配置好一个tomcat,复制完文件后,再将tomcat文件重新复制一份,这样省事,但需要修改tomcat相应的端口)

 

第二步:

 

Java代码  收藏代码
  1. 2. Add tomcat system property "catalina.base"  
  2.         * catalina.base="TOMCAT_LOCATION"  

 就是配置一个环境变量,和Jdk配置的环境变量一样,需要配置一个catalina.base的环境变量,值为TOMCAT_LOCATION

 

如下:



 



 

 

第三步:

 

Java代码  收藏代码
  1. 3. Extract downloaded package (tomcat-cluster-redis-session-manager.zip) to configure Redis credentials in redis-data-cache.properties file and move the file to tomcat/conf directory  
  2.         * tomcat/conf/redis-data-cache.properties  

 把conf目录下的配置文件redis-data-cache.properties复制到tomcat/conf/目录下

 

 

第四步:

 

Java代码  收藏代码
  1. 4. Add the below two lines in tomcat/conf/context.xml  
  2.         <Valve className="tomcat.request.session.redis.SessionHandlerValve" />  
  3.         <Manager className="tomcat.request.session.redis.SessionManager" />  

 在tomcat/conf/目录下的context.xml文件,加上相应的配置,如下:

 

 

Xml代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2.   
  3. <!--  
  4.   Licensed to the Apache Software Foundation (ASF) under one or more  
  5.   contributor license agreements.  See the NOTICE file distributed with  
  6.   this work for additional information regarding copyright ownership.  
  7.   The ASF licenses this file to You under the Apache License, Version 2.0  
  8.   (the "License"); you may not use this file except in compliance with  
  9.   the License.  You may obtain a copy of the License at  
  10.   
  11.       http://www.apache.org/licenses/LICENSE-2.0  
  12.   
  13.   Unless required by applicable law or agreed to in writing, software  
  14.   distributed under the License is distributed on an "AS IS" BASIS,  
  15.   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  
  16.   See the License for the specific language governing permissions and  
  17.   limitations under the License.  
  18. --><!-- The contents of this file will be loaded for each web application --><Context>  
  19.   
  20.     <!-- Default set of monitored resources. If one of these changes, the    -->  
  21.     <!-- web application will be reloaded.                                   -->  
  22.     <WatchedResource>WEB-INF/web.xml</WatchedResource>  
  23.     <WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>  
  24.   
  25.     <!-- Uncomment this to disable session persistence across Tomcat restarts -->  
  26.     <!-- 
  27.     <Manager pathname="" /> 
  28.     -->  
  29.   
  30.     <!-- Uncomment this to enable Comet connection tacking (provides events  
  31.          on session expiration as well as webapp lifecycle) -->  
  32.     <!-- 
  33.     <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" /> 
  34.     -->  
  35.     <Valve className="tomcat.request.session.redis.SessionHandlerValve"/>  
  36.     <Manager className="tomcat.request.session.redis.SessionManager"/>  
  37.   
  38. </Context>  

 

 

第五步:

 

Java代码  收藏代码
  1. 5. Verify the session expiration time (minutes) in tomcat/conf/web.xml  
  2.         <session-config>  
  3.             <session-timeout>60<session-timeout>  
  4.         <session-config>  

 修改session的过期时间,默认是30分钟,可以不需要此步骤。

 

 

session集群的配置至此结束。

 

四、Nginx集群

1、下载Nignx:http://nginx.org/en/download.html

本人练习时使用windows,所以下载的windows版本:http://nginx.org/download/nginx-1.13.7.zip

 

2、下载后解压:D:\soft\nginx-1.12.2 (之前使用的是1.12.2的版本,现在最新版是1.13.7,但都一样,附件中有1.12.2版本提供下载)



 

3、修改Nginx配置文件nginx.conf

进入conf目录(D:\soft\nginx-1.12.2\conf),找到nginx.conf配置文件,打开编辑:

 

3.1在http{……}里加上upstream,如下:

 

Java代码  收藏代码
  1. upstream myTomcatCluster{# tomcatCluster和proxy_pass保持一样    
  2.         #解决session的问题    
  3.         #ip_hash;#加上这个,解决Session每次访问页面都不一样,加上就一样了。    
  4.             
  5.         #这里是tomcat的地址,weight越大,访问机率越大。    
  6.         server 127.0.0.1:9300 weight=1 fail_timeout=5s max_fails=1;    
  7.         server 127.0.0.1:9400 weight=1 fail_timeout=5s max_fails=1;    
  8.     }   

 server:配置tomcat服务器请求的地址,2台Tomcat服务就配置2个server,分别对应9300,9400端口

 

weight 表示权重,权重越大,访问到的机率越大。

 

3.2、修改location / {……}

默认是这个的:

Xml代码  收藏代码
  1. location / {  
  2.             root   html;  
  3.             index  index.html index.htm;  
  4.         }  

 

修改成这样:

Xml代码  收藏代码
  1. location / {  
  2.             #root   html;  
  3.         proxy_pass http://myTomcatCluster;  
  4.             #index  index.html index.htm;  
  5.         proxy_set_header Host $host;  
  6.             proxy_set_header X-Real-IP $remote_addr;  
  7.             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  8.             proxy_connect_timeout       1;  
  9.             proxy_read_timeout          1;  
  10.             proxy_send_timeout          1;   
  11.         }  

 

最简单的配置就是:

Xml代码  收藏代码
  1. location / {  
  2.      proxy_pass http://myTomcatCluster;  
  3. }  

 myTomcatCluster 对应upstream后的命名。

 

下面的配置可以解决2个Tomcat服务器集群,当一台服务器挂掉(宕机)后,请求变得很慢的问题。

(Tomcat集群一台服务器挂掉后请求变慢解决方案)

Xml代码  收藏代码
  1. proxy_connect_timeout       1;  
  2. proxy_read_timeout          1;  
  3. proxy_send_timeout          1;   

3.3、启动Nginx服务器

使用Windows命令行启动

(1)进入D盘:d:

(2)进入D:\soft\nginx-1.12.2目录:

Java代码  收藏代码
  1. cd D:\soft\nginx-1.12.2  

(3)启动服务: (启动一闪而过,但打开进程管理器能看到是已经启动的)

Java代码  收藏代码
  1. start nginx  

关闭服务的命令:nginx -s stop

重新加载的命令:nginx -s reload,修改配置文件后,可以使用该命令直接加载,不需要重启。

 

 

五、测试集群:

1、tomcat准备

将已经配置好的一个tomcat复制一份,修改端口,然后再修改一下tomcat的配置文件(server.xml)

我的一个tomcat在:D:\soft\apache-tomcat-8.0.45-9300\conf

另一个是:D:\soft\apache-tomcat-8.0.45-9400\conf

 

修改:

Xml代码  收藏代码
  1. <Engine defaultHost="localhost" name="Catalina">  

 其中tomcat 9300端口的修改如下:

Xml代码  收藏代码
  1. <Engine defaultHost="localhost" jvmRoute="jvm9300" name="Catalina">  

 tomcat 9400端口的修改如下:

Java代码  收藏代码
  1. <Engine defaultHost="localhost" jvmRoute="jvm9400" name="Catalina">  

 

2、项目准备:

新建立一个web项目,然后新建立一个index.jsp的文件,如下:

Html代码  收藏代码
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>首页redis-session</title>  
  8. </head>  
  9. <body>  
  10.     <div>tomcat 集群测试</div>  
  11.     <div>  
  12.         <%     
  13.           //HttpSession session = request.getSession(true);     
  14.           System.out.println(session.getId());     
  15.           out.println("<br> SESSION ID:" + session.getId()+"<br>");     
  16.         %>  
  17.     </div>  
  18. </body>  
  19. </html>  

 主要是在打印页面输出sessionId的信息:

Html代码  收藏代码
  1. out.println("<br> SESSION ID:" + session.getId()+"<br>");  

 

然后把这个项目分别部署到9300、9400端口的2个tomcat中,分别启动,记得也启动Nginx和redis哦

然后打开浏览器通过地址访问项目:http://localhost/redis-session/ (使用Nginx集群分发,不需要端口号访问),显示如下:

Java代码  收藏代码
  1. tomcat 集群测试  
  2.   
  3. SESSION ID:B837ECA85B47081EAA2FEFCD7E579CD2.jvm9400  

 无论怎么刷新访问(打开新的标签页也是(非新窗口))的都是jvm9400,也就是端口号为9400的tomcat

后缀.jvm9400就是前面配置的:

Java代码  收藏代码
  1. <Engine defaultHost="localhost" jvmRoute="jvm9400" name="Catalina">  

 

打开新的隐身窗口访问:

Java代码  收藏代码
  1. tomcat 集群测试  
  2.   
  3. SESSION ID:83BBA58F4EB7B2EFF90AE05D4A0629FD.jvm9300  

 这时访问的是端口号为9300的tomcat,通过后缀.jvm9300判断知道。

新窗口每次访问的是都是tomcat9300,session也不会变。

 

在访问后缀为.jvm9400时,把端口9400的tomcat关掉,再次刷新访问,sessionId一样不变,由此可见,2个tomcat的sessionId是共享的。

 

使用Redis实现session共享的好处就是,把session管理放在redis中,如果服务器重启或挂机,sessionId保存在redis中,下次重启后一样生效,避免sessionId失效,同样redis最好也做集群,避免redis重启或挂机。

 

 

结束了。

分享到:
评论

相关推荐

    Redis + Tomcat + Nginx 集群实现 Session 共享.pdf

    Redis + Tomcat + Nginx 集群实现 Session 共享

    nginx+tomcat+redis完成session共享

    这个小例子"nginx+tomcat+redis完成session共享"旨在演示如何通过这三种技术实现跨服务器的用户会话共享,以提升用户体验并简化系统管理。以下是这些技术及其在会话共享中的作用: 1. **Nginx**:Nginx是一款高性能...

    redis缓存服务器Nginx+Tomcat+redis+MySQL实现session会话共享

    "redis缓存服务器Nginx+Tomcat+redis+MySQL实现session会话共享"的主题旨在探讨如何利用这些技术组件来实现这一目标。以下是相关知识点的详细说明: **Redis**:Redis是一个高性能的键值数据存储系统,常用于做缓存...

    Nginx+Keepalived+Redis+Tomcat

    根据提供的文件信息,本文将详细解析如何在Linux环境下构建Nginx+Keepalived+Redis+Tomcat集群,实现session共享、负载均衡以及高可用性。以下内容将围绕集群规划与具体实施步骤展开。 ### 一、集群规划 在进行...

    nginx+tomcat+redis集群配置session共享(下载运行即可)+详细说明

    本实例基于nginx+tomcat+redis的集群实现,实现session的复制。压缩包内含两个tomcat+一个nginx服务器+64位windows版的redis+说明文档,下载即可运行,详细步骤可以参考文档,从此告别集群盲区

    Redis+nginx集群部署

    **标题:Redis+nginx集群部署** **描述:**在本实践中,我们将结合Tomcat应用服务器、Nginx反向代理服务器以及Redis作为会话存储来建立一个高可用、负载均衡的Web集群。Nginx负责将用户请求分发到各个Tomcat实例,...

    redis+tomcat+nginx负载均衡配置

    在负载均衡场景中,Redis可以作为Session共享的存储,避免用户在多台Tomcat服务器之间切换时丢失Session信息。 2. **Tomcat**:Tomcat是Apache软件基金会的一个开源Java Servlet容器,支持Java Web应用程序的部署。...

    tomcat+redis+nginx实现session共享所需jar包

    tomcat+redis+nginx实现session共享所需jar包,包含commons-pool2-2.4.2.jar、jedis-2.8.0.jar、tomcat-redis-session-manager-2.0.0.jar

    Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享.zip

    计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习...

    tomcat7 + redis + nginx 实现session共享的jar包

    4. Session共享实现:在Tomcat中,可以通过配置`Context`元素的`Manager`子元素来启用RedisSessionManager。这个manager会将session数据存储在Redis中,而不是默认的内存或者硬盘。此外,Nginx需要配置适当的负载...

    spring4+redis3+nginx1实现tomcat集群session共享源码

    本文将详细介绍如何使用Spring、Redis和Nginx来实现Tomcat集群中的Session共享,以及提供相关的源码下载。 首先,我们来看Spring框架。Spring是Java开发中最流行的开源框架之一,它提供了丰富的功能和模块,包括...

    Nginx+Redis+Tomcat 集群部署

    在构建高性能、高可用性的Web服务时,"Nginx+Redis+Tomcat 集群部署"是一种常见的架构模式。这种模式结合了Nginx的反向代理和负载均衡能力,Redis的数据缓存功能,以及Tomcat的Java应用服务器性能,能够有效提升系统...

    redis+tomcat+nginx分布式部署

    本文将围绕“Redis + Tomcat + Nginx”的分布式部署模式进行深入探讨,包括Nginx的负载均衡配置、Tomcat的分布式部署及Redis实现的Session共享机制。 #### 一、Nginx配置负载均衡 Nginx作为一款高性能的HTTP和反向...

    nginx+Redis+tomcat实现session共享测试代码

    总的来说,"nginx+Redis+tomcat实现session共享测试代码"是一个典型的Web服务集群解决方案,通过结合Nginx的反向代理、Redis的分布式缓存以及Tomcat的应用托管,有效地解决了跨应用Session管理的问题。对于学习和...

    tomcat8+Redis+nginx

    在集群部署中,多个Tomcat实例可以分布在不同的服务器上,通过共享session数据来实现会话持久性,提高服务的可用性和扩展性。 其次,Redis是一个高性能的键值存储系统,常用于缓存解决方案。在“tomcat8+Redis”...

    Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享

    超详细Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享搭建说明,按文档步骤可轻松搭建并实现session共享

    linux nginx+redis+tomcat分布式负载均衡生产环境部署完成

    技术:reids集群 nginx部署 tomcat负载均衡 说明包含: nginx+redis+tomcat分布式负载均衡文档 session共享资料 安装程序 nginx+redis+tomcat分布式负载均衡部署帮助文档 nginx+redis+tomcat分布式负载均衡...

    Nginx+tomcat+redis

    - **session共享**:在分布式环境中,Redis可以作为session存储,解决跨服务器的session共享问题,确保用户会话的一致性。 - **消息队列**:Redis支持发布/订阅模型,可以作为简单消息队列,用于异步处理任务或...

    nginx+tomcat集群+redis实现session共享

    目前只支持tomcat8.5,其它版本的tomcat还没测试,自己配置过很多nginx+tomcat集群+redis实现session共享的系统,经过仔细总结得出这些,可以说是知识的结晶,欢迎大家来下载,不好的地方可以多提,有问题看到的话会...

Global site tag (gtag.js) - Google Analytics