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 ...
随机推荐
- Java入门到实践系列(2)——Java环境搭建
一.上集回顾 在<Java入门到实践系列(1)--Java简介>中提到过,Java程序是运行在Java虚拟机的,也展示过下面这张图. JDK:Java程序开发工具包. JRE:Java运行 ...
- 【计算机算法设计与分析】——SVM
一.简介 支持向量机(support vector machines)是一种二分类模型,它的目的是寻找一个超平面来对样本进行分割,分割的原则是间隔最大化,最终转化为一个凸二次规划问题来求解.由简至繁的 ...
- 如何实现数据库CDP,即数据库连续数据保护
备份可以分为定期备份和实时备份.定期备份与实时备份相比存在两大劣势:一是备份需要时间窗口,对于很多24小时业务运行的机构,线上业务不允许有过多的业务系统停机去进行数据备份:二是定期备份无法保证数据丢失 ...
- C#设计模式之23-访问者模式
访问者模式(Vistor Pattern) 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/431 访问. 访问者模式属于 ...
- C#LeetCode刷题-双指针
双指针篇 # 题名 刷题 通过率 难度 3 无重复字符的最长子串 24.5% 中等 11 盛最多水的容器 43.5% 中等 15 三数之和 16.1% 中等 16 最接近的三数之和 3 ...
- Antd cracoTs Js 配置流程
JS:文档:0.1.4 配置 js 环境.note链接:http://note.youdao.com/noteshare?id=e32fa75c1baa014b5819fa5e22887dbc& ...
- JavaScript学习系列博客_28_JavaScript 数组去重
数组去重 var arr = [1,2,3,2,2,1,3,4,2,5]; //去除数组中重复的数字 //获取数组中的每一个元素 for(var i=0 ; i<arr.length ; i++ ...
- JavaScript学习系列博客_24_JavaScript 原型对象
原型(prototype) - 创建一个函数(所有函数)以后,解析器都会默认在函数中添加一个属性prototype prototype属性指向的是一个对象,这个对象我们称为原型对象. 创建一个函数My ...
- Linux查看系统硬件信息命令汇总
对工作中,经常用的查看系统硬件命令的一个简单总结 1.查看磁盘类型(是否SSD盘)cat /sys/block/sda/queue/rotational注意:命令中的sba是你的磁盘名称,可以通过df ...
- 安全可靠国产系统背景下的应用开发应有.NET Core的一席之地
在中美当前背景下的安全可靠国产系统(简称安可),安可产业要实现技术自主可控,需要在四个层面逐步实现:基础硬件设施,如芯片.服务器.存储.交换机.路由器:底层软件,包括操作系统.数据库.中间件等:应用软 ...