Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享
Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享
=============================
蕃薯耀 2017年11月27日
http://www.cnblogs.com/fanshuyao/
代码美化版或附件下载见:http://fanshuyao.iteye.com/blog/2400975
一、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的配置文件
- #-- Redis data-cache configuration
- #- redis hosts ex: 127.0.0.1:6379, 127.0.0.2:6379, 127.0.0.2:6380, ....
- redis.hosts=127.0.0.1:6379
- #- redis password (for stand-alone mode)
- #redis.password=
- #- set true to enable redis cluster mode
- redis.cluster.enabled=false
- #- redis database (default 0)
- #redis.database=0
- #- redis connection timeout (default 2000)
- #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 文件:
第一步:
- 1. Move the downloaded jars to tomcat/lib directory
- * tomcat/lib/
就是把lib目录下的Jar包全复制到tomcat/lib目录下
(一般来说tomcat是集群,至少有2个tomcat,所以先配置好一个tomcat,复制完文件后,再将tomcat文件重新复制一份,这样省事,但需要修改tomcat相应的端口)
第二步:
- 2. Add tomcat system property "catalina.base"
- * catalina.base="TOMCAT_LOCATION"
就是配置一个环境变量,和Jdk配置的环境变量一样,需要配置一个catalina.base的环境变量,值为TOMCAT_LOCATION
如下:
第三步:
- 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
- * tomcat/conf/redis-data-cache.properties
把conf目录下的配置文件redis-data-cache.properties复制到tomcat/conf/目录下
第四步:
- 4. Add the below two lines in tomcat/conf/context.xml
- <Valve className="tomcat.request.session.redis.SessionHandlerValve" />
- <Manager className="tomcat.request.session.redis.SessionManager" />
在tomcat/conf/目录下的context.xml文件,加上相应的配置,如下:
- <?xml version="1.0" encoding="UTF-8"?>
- <!--
- Licensed to the Apache Software Foundation (ASF) under one or more
- contributor license agreements. See the NOTICE file distributed with
- this work for additional information regarding copyright ownership.
- The ASF licenses this file to You under the Apache License, Version 2.0
- (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- --><!-- The contents of this file will be loaded for each web application --><Context>
- <!-- Default set of monitored resources. If one of these changes, the -->
- <!-- web application will be reloaded. -->
- <WatchedResource>WEB-INF/web.xml</WatchedResource>
- <WatchedResource>${catalina.base}/conf/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="tomcat.request.session.redis.SessionHandlerValve"/>
- <Manager className="tomcat.request.session.redis.SessionManager"/>
- </Context>
第五步:
- 5. Verify the session expiration time (minutes) in tomcat/conf/web.xml
- <session-config>
- <session-timeout>60<session-timeout>
- <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,如下:
- upstream myTomcatCluster{# tomcatCluster和proxy_pass保持一样
- #解决session的问题
- #ip_hash;#加上这个,解决Session每次访问页面都不一样,加上就一样了。
- #这里是tomcat的地址,weight越大,访问机率越大。
- server 127.0.0.1:9300 weight=1 fail_timeout=5s max_fails=1;
- server 127.0.0.1:9400 weight=1 fail_timeout=5s max_fails=1;
- }
server:配置tomcat服务器请求的地址,2台Tomcat服务就配置2个server,分别对应9300,9400端口
weight 表示权重,权重越大,访问到的机率越大。
3.2、修改location / {……}
默认是这个的:
- location / {
- root html;
- index index.html index.htm;
- }
修改成这样:
- location / {
- #root html;
- proxy_pass http://myTomcatCluster;
- #index index.html index.htm;
- proxy_set_header Host $host;
- proxy_set_header X-Real-IP $remote_addr;
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- proxy_connect_timeout 1;
- proxy_read_timeout 1;
- proxy_send_timeout 1;
- }
最简单的配置就是:
- location / {
- proxy_pass http://myTomcatCluster;
- }
myTomcatCluster 对应upstream后的命名。
下面的配置可以解决2个Tomcat服务器集群,当一台服务器挂掉(宕机)后,请求变得很慢的问题。
(Tomcat集群一台服务器挂掉后请求变慢解决方案)
- proxy_connect_timeout 1;
- proxy_read_timeout 1;
- proxy_send_timeout 1;
3.3、启动Nginx服务器
使用Windows命令行启动
(1)进入D盘:d:
(2)进入D:\soft\nginx-1.12.2目录:
- cd D:\soft\nginx-1.12.2
(3)启动服务: (启动一闪而过,但打开进程管理器能看到是已经启动的)
- 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
修改:
- <Engine defaultHost="localhost" name="Catalina">
其中tomcat 9300端口的修改如下:
- <Engine defaultHost="localhost" jvmRoute="jvm9300" name="Catalina">
tomcat 9400端口的修改如下:
- <Engine defaultHost="localhost" jvmRoute="jvm9400" name="Catalina">
2、项目准备:
新建立一个web项目,然后新建立一个index.jsp的文件,如下:
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>首页redis-session</title>
- </head>
- <body>
- <div>tomcat 集群测试</div>
- <div>
- <%
- //HttpSession session = request.getSession(true);
- System.out.println(session.getId());
- out.println("<br> SESSION ID:" + session.getId()+"<br>");
- %>
- </div>
- </body>
- </html>
主要是在打印页面输出sessionId的信息:
- out.println("<br> SESSION ID:" + session.getId()+"<br>");
然后把这个项目分别部署到9300、9400端口的2个tomcat中,分别启动,记得也启动Nginx和redis哦
然后打开浏览器通过地址访问项目:http://localhost/redis-session/ (使用Nginx集群分发,不需要端口号访问),显示如下:
- tomcat 集群测试
- SESSION ID:B837ECA85B47081EAA2FEFCD7E579CD2.jvm9400
无论怎么刷新访问(打开新的标签页也是(非新窗口))的都是jvm9400,也就是端口号为9400的tomcat
后缀.jvm9400就是前面配置的:
- <Engine defaultHost="localhost" jvmRoute="jvm9400" name="Catalina">
打开新的隐身窗口访问:
- tomcat 集群测试
- 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重启或挂机。
结束了。
=============================
蕃薯耀 2017年11月27日
http://www.cnblogs.com/fanshuyao/
Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享的更多相关文章
- Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群
Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群 >>>>>>>>>>>> ...
- Tomcat学习总结(8)——Tomcat+Nginx集群解决均衡负载及生产环境热部署
近日,为解决生产环境热部署问题,决定在服务器中增加一个tomcat组成集群,利用集群解决热部署问题. 这样既能解决高并发瓶颈问题,又能解决热部署(不影响用户使用的情况下平滑更新生产服务器)问题. 因为 ...
- windows Tomcat+Nginx 集群 迷你版
一. 准备 两个Tomcat 加上Nginx 2. 创建一个公共的文件夹用于部署项目 3. Tomcat配置 配置内存 在catalina.bat 第一行增加 set JAVA_OPTS=-Xms51 ...
- 腾讯云CentOS 7搭建简单Tomcat+nginx集群
1.安装Tomcat 进入 /usr/local/ 目录 cd /usr/local 下载 wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-9/v ...
- Nginx+Tomcat搭建集群,Spring Session+Redis实现Session共享
小伙伴们好久不见!最近略忙,博客写的有点少,嗯,要加把劲.OK,今天给大家带来一个JavaWeb中常用的架构搭建,即Nginx+Tomcat搭建服务集群,然后通过Spring Session+Redi ...
- nginx+tomcat实现集群,redis实现session共享,软连接实现文件共享:http://blog.csdn.net/hua1586981/article/details/78132710
转载 2017年02月08日 16:52:41 730 相信很多人都听过nginx,这个小巧的东西慢慢地在吞食apache和IIS的份额.那究竟它有什么作用呢?可能很多人未必了解. 说到反向代理,可能 ...
- Nginx集群配置与redis的session共享策略
一.什么是Nginx? Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Ramb ...
- Spring Boot+redis存储session,满足集群部署、分布式系统的session共享
本文讲述spring-boot工程中使用spring-session机制进行安全认证,并且通过redis存储session,满足集群部署.分布式系统的session共享. 原文链接:https://w ...
- 注意这几点,轻轻松松配置 Nginx + Tomcat 的集群和负载均衡
Tomcat 集群是当单台服务器达到性能瓶颈,通过横向扩展的方式提高整体系统性能的有效手段.Nginx 是一个高性能的 HTTP 和反向代理 web 服务器,可以通过简单的配置实现 Tomcat 集群 ...
随机推荐
- Android Parcelable理解与使用(对象序列化)
http://my.oschina.net/zhoulc/blog/172163 parcel定义介绍: android提供了一种新的类型:parcel(英文解释:包裹,小包),本类用来封装数据的容器 ...
- OpenWRT UCI命令实现无线中继
本文主要功能主要是利用OpenWRT系统uci命令实现无线中继,主要是利用uci程序修改/etc/congfig/目录下的配置文件.实现步骤如下主要分为以下几步: 1) 安装 relayd (opkg ...
- 【转】NOR Flash擦写和原理分析
1. NOR FLASH 的简单介绍 NOR FLASH 是很常见的一种存储芯片,数据掉电不会丢失.NOR FLASH支持Execute On Chip,即程序可以直接在FLASH片内执行(这意味着存 ...
- 使用bitset实现毫秒级查询(二)
在上一篇中我们了解了bitset索引的基本用法,本篇开始学习bitset索引更新及一些复杂查询. 1.bitset索引更新 因为我们的数据是在系统启动时全部加载进内存,所以当数据库数据发生变化时要 ...
- mysql 中select for update 锁表的范围备注
mysql的锁表范围测试 1.主键明确时,行级锁: 解释:指定主键并且数据存在时,仅锁定指定的行,其它行可以进行操作 实例:指定了锁定id=1的行且数据存在①,在更新1时lock wait超时②,但是 ...
- PHP简洁之道
前言 前几天在GitHub看到一篇写PHP简洁之道的译文,觉得还不错,所以转在了自己的博客中,只不过有一些地方好像没有翻译,再加上排版上的一些小问题,所以决定自己翻译一遍. 原文地址:https:// ...
- Memcached统计命令
1. Memcached stats命令: Memcached stats 命令用于返回统计信息例如 PID(进程号).版本号.连接数等. 语法: stats 输出信息说明: pid: memcach ...
- LeetCode 190. Reverse Bits (反转位)
Reverse bits of a given 32 bits unsigned integer. For example, given input 43261596 (represented in ...
- Python爬虫之爬取慕课网课程评分
BS是什么? BeautifulSoup是一个基于标签的文本解析工具.可以根据标签提取想要的内容,很适合处理html和xml这类语言文本.如果你希望了解更多关于BS的介绍和用法,请看Beautiful ...
- 每天一个linux命令(26):用SecureCRT来上传和下载文件(转载自竹子)
用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...