Tomcat7.0.99集群使用Redis共享session方案
以前配置过给予多播的session共享方案,这回再配置一个redis共享session的。

先小小的炫耀一下:

相信大家要做Tomcat+Redis+session配置,遇到的头号麻烦就是编译的tomcat-redis-session-manager,真是苦了我们这群伸手党,作者James Coleman同学帮人也不帮到底,直接提供三个jar下载不好吗?
我本着助人为乐的精神,借花献佛,提供三个jar下载地址:https://files.cnblogs.com/files/xiandedanteng/tomcat7-redis-session-manager.rar ,而我是从 http://pan.baidu.com/s/1qWXgNTy 下载的,在此向作者表示敬意;美中不足是 ,这位作者提供另一个的https://jingyan.baidu.com/article/ac6a9a5e10415f2b653eace8.html 最底下的http://pan.baidu.com/s/1dELCFVb 中,对apache-tomcat-8.5.50是不好用的,三个jar放进去,设定context.xml,一启动tomcat8就报异常,然后tomcat都起不来,真是遗憾(发现作者的jar是对tomcat8.0版本的,并不适合8.5.50版本。2020年1月5日14点25分)。
我的环境:
操作系统:Win10
Tomcat:apache-tomcat-7.0.99-windows-x64
Redis:Redis-x64-3.2.100
都是win版的,大家可以熟悉了再去linux下面去配,道理都是一样的。
具体配置开始:
1.安装Redis,请参考另一篇文章:https://www.cnblogs.com/xiandedanteng/p/12147921.html
2.下载配置Tomcat
从Tomcat官网将apache-tomcat-7.0.99下载下来后,解压,拷贝到本地的两个目录:

然后,分别编辑两个tomcat的startup.bat,将以下两行文字插到文件头部:
set JAVA_HOME="C:\Java8"
set CATALINA_HOME="C:\Install\tomcat7rediscluster\tomcat01"
第一句是告诉tomcat javahome在哪里,这不需要修改,第二句则是自己所在的物理地址,是需要根据目录变动的。
之后,需要修改tomcat02的server.xml文件,将三个端口改掉。
<Server port="8006" shutdown="SHUTDOWN">
...
<Connector port="8088" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
...
<Connector port="8019" protocol="AJP/1.3" redirectPort="8443" />
这三个端口,我是从8005,8080,8009修改过来的。
这一步是为了两个tomcat端口互相不干扰,之后可以启动两个tongcat测试一下。
3.拷贝redis相关jar包到两个tomcat的lib目录:
https://files.cnblogs.com/files/xiandedanteng/tomcat7-redis-session-manager.rar 下载之,解压之,拷贝之。
4.拷贝myweb.war到两个tomcat的webapps目录
下载地址:https://www.cnblogs.com/xiandedanteng/p/12143132.html
这个web应用是用来看sessionid的。
5.设置两个tomcat的context.xml,我的设置如下:
Tomcat1:
<?xml version='1.0' encoding='utf-8'?>
<Context>
<!-- Default set of monitored resources -->
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="192.168.0.106"
port="6379"
database="0"
password="ufo"
maxInactiveInterval="60" />
</Context>
Tomcat2:
<?xml version='1.0' encoding='utf-8'?>
<Context>
<!-- Default set of monitored resources -->
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="192.168.0.106"
port="6379"
database="0"
password="ufo"
maxInactiveInterval="60" />
</Context>
两个文件是一摸一样,其中host是自己的IP,port是redis启动端口,password是你在redis.windows.conf里设置的密码,别搞错了。
之后打开cmd窗口,分别到两个tomcat的bin目录,执行startup.bat以启动两个tomcat,,到localhost:8080/myweb 和 localhost:8088/myweb 看看session id是否一致就行了。如果你也看到两个session id一致,那么祝贺你。
写到这里,忽然想到人家写好配过的,我照做一遍,是否值得得意呢?相对于人家先行者,我无疑是跟随着,但相对于昨天的我,今天知道怎么配的我无疑是进步的,从此我又打开了一扇门,其后是更广阔的天地,这难道不是一件值得小得意的事情吗?你觉得呢?


--END-- 2020年1月4日 09点54分
Tomcat7.0.99集群使用Redis共享session方案的更多相关文章
- Nginx+tomcat集群使用redis共享session
一 :nginx负载均衡 当Tomcat当做独立的Servlet容器来运行时,可看做是能运行Java Servlet的独立Web服务器. 此外 Tomcat还可以作为其他Web服务器进程内或者进程外的 ...
- nginx+tomcat实现集群,redis实现session共享,软连接实现文件共享:http://blog.csdn.net/hua1586981/article/details/78132710
转载 2017年02月08日 16:52:41 730 相信很多人都听过nginx,这个小巧的东西慢慢地在吞食apache和IIS的份额.那究竟它有什么作用呢?可能很多人未必了解. 说到反向代理,可能 ...
- apache2.2.25+tomcat7.0.47集群方案
因为公司项目在线人数的增加,随着现在硬件成本越来越低,大多数的生产环境内存大多都已经达到 16G,尤其最新的阿里云,客户的机器都是配置超高的java主机,但是Java的运行环境,内存使用有限 ,这样就 ...
- 使用Nginx搭建Tomcat9集群,Redis实现Session共享
使用Nginx搭建Tomcat9集群,Redis实现Session共享 1.tomcat准备 首先准备两个tomcat9 ,修改配置文件server.xml 如果在多个服务器上分别启动tomcat 则 ...
- (转)apache2.2.x+tomcat7.0.x集群+…
apache http server下载地址 http://httpd.apache.org/download.cgi#apache22 这里下载的是httpd-2.2.21-win32-x86-op ...
- 一篇文章让你深透理解cookie和session,附带分布式WEB系统redis共享session方案
cookie和session有什么区别?这是一个很基础的知识点,大家可能都知道一个大概:cookie是存在客户端的,session是存储在服务端,cookie和session用来验证识别用户的登录状态 ...
- Tomcat 7集群基于redis的session共享设置
经过测试之后,发现是tomcat中redis相关jar包问题,替换jar包后A产品运行正常. tomcat/lib目录下将commons-pool2-2.1.jar.jedis-2.1.0.jar.t ...
- linux下实现redis共享session的tomcat集群
为了实现主域名与子域名的下不同的产品间一次登录,到处访问的效果,因此采用rediss实现tomcat的集群效果.基于redis能够异步讲缓存内容固化到磁盘上,从而当服务器意外重启后,仍然能够让sess ...
- 配置redis 4.0.11 集群
配置redis 4.0.11 集群 准备redis 软件和redis配置文件 启动Redis服务 /data/soft/redis/src/redis-check-aof --fix /log/red ...
随机推荐
- Zabbix5 对接 SAML 协议 SSO
Zabbix5 对接 SAML 协议 SSO 在 Zabbix5.0 开始已经支持 SAML 认证 官文文档: https://www.zabbix.com/documentation/current ...
- Eclipse变得很卡
半个月前,发现Eclipse很卡很卡,尤其在按住Ctrl选择方法的实现类的时候,电脑的反应速度让开发者无法忍受. Eclipse还经常未响应状态. 开始以为Eclipse的运行内存设置小了,把ecli ...
- java JDBC工具类
package com.oracle.tools; import java.sql.Connection; import java.sql.DriverManager; import java.sql ...
- C#LeetCode刷题之#705-设计哈希集合(Design HashSet)
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/4114 访问. 不使用任何内建的哈希表库设计一个哈希集合 具体地说 ...
- Vue Slots
子组件vue <template> <div> <slot v-if="slots.header" name="header"&g ...
- Dubbo系列之 (二)Registry注册中心-注册(2)
引导 本章主要介绍下AbstractRegistry.FailbackRegistry的作用和源码. AbstractRegistry 首先,直接引出这个类的作用,该类主要把服务提供者信息缓存本地文件 ...
- vue安装和卸载
安装最新版本 npm install -g @vue/cli或 yarn global add @vue/cli 卸载之前版本npm uninstall vue-cli -g 或 yarn globa ...
- 关于数据库新建用户提示“用户、组或角色‘’XXX‘’在当前数据库中已已存在”的解决办法
一般在还原数据库后,给这个数据库添加一个登录名时出现. 例如数据库备份文件中已经包含了用户abc,现在还原了数据库,然后发现现有数据库中没有abc这个用户,想要新建一个abc用户,作为该数据库的own ...
- Python 用DataFrame读 存 excel
读 代码: import pandas as pd e = r'D:\pywork\12\excel信息表.xlsx' df = pd.DataFrame(pd.read_excel(e)) 存 D. ...
- Nginx学习简记_part1
内容概览 nginx简介 (1)介绍nginx的应用场景和具体可以做什么事情 (2)介绍什么是反向代理 (3)介绍什么是负载均衡 (4)介绍什么是动静分离 nginx安装 (1)介绍nginx在lin ...