Tomcat session复制及session共享技术

目录

1、环境

2、配置测试页面

3、配置session共享


前言:

为什么要做session复制或共享

实现Session复制或Session共享的目的是为了在多个Tomcat实例之间实现Session的无缝转移和共享,以提供更高的可伸缩性、负载均衡和容错性。以下是一些原因:

  1. 高可用性和容错性:通过复制或共享Session,当一个Tomcat实例发生故障或停机时,其他实例可以接管并继续处理用户请求,而不会丢失Session数据。这确保了应用程序的高可用性和容错性。

  2. 负载均衡:当有多个Tomcat实例运行时,Session复制或共享可以实现负载均衡。用户的请求可以分散到不同的实例上,提高系统的整体性能和吞吐量。

  3. 无状态化应用设计:通过将Session数据从应用服务器中移出,可以使应用程序变得更加无状态化。这意味着每个请求可以独立处理,不依赖于特定的服务器状态,从而提高应用程序的可扩展性。

  4. 保持用户会话状态:通过Session复制或共享,用户的会话状态可以在多个请求之间得到保持。这对于需要跨页面或多个请求保持用户身份、购物车信息、用户首选项等状态非常重要。

1、环境

服务 IP
nginx 10.12.153.203
tomcat 10.12.153.203
tomcat2 10.12.153.203
tomcat3 10.12.153.203

注:我这里是在一台服务器配置的tomcat多实例做实验,基于Tomcat运维-CSDN博客最后的环境,也可以部署在不同服务器

2、配置测试页面

sql 复制代码
vim /usr/local/tomcat/webapps/ROOT/session.jsp   #编写一个测试页面

cd /usr/local/

cp tomcat/webapps/ROOT/session.jsp tomcat2/webapps/ROOT/session.jsp  

cp tomcat/webapps/ROOT/session.jsp tomcat3/webapps/ROOT/session.jsp

浏览器访问:

10.12.153.203/session.jsp (可以看到每刷新一次网页都会生成一个新的ID)

3、配置session共享

在官网找文档:Apache Tomcat® - Welcome!

sql 复制代码
vim tomcat/conf/server.xml

然后找到这一部分(在server.xml里面配置,所有tomcat实例)

sql 复制代码
vim /usr/local/tomcat/webapps/ROOT/WEB-INF/web.xml 

其他实例相同配置,4000端口不同

然后重新启动服务浏览器访问即可

可以看到ID不变了,只有主机名在变

官方建议,不超过四个节点可以使用这个方法,因为他是all-to-all的模式,频繁的广播session信息会造成负载过高

cookie 和 session 到底是什么 - 知乎

nginx+tomcat+redis实现session共享_nginx tomcat redis实现session共享-CSDN博客

相关推荐
Json_9 分钟前
学习springBoot框架-开发一个酒店管理系统,熟悉springboot框架语法~
java·spring boot·后端
kkkkk02110616 分钟前
微服务学习笔记(黑马商城)
java·spring boot·spring·spring cloud·sentinel·mybatis·java-rabbitmq
2503_9301239317 分钟前
Kubernetes (六)调度策略详解:从节点匹配到Pod调度全流程
java·开发语言
曾凡宇先生18 分钟前
openEuler安装jdk,nginx,redis
linux·开发语言·数据库·openeuler
_OP_CHEN18 分钟前
Linux系统编程:(三)基础指令详解(2)
linux·man·more·cat·linux指令·cp·whereis
安卓开发者25 分钟前
Docker常用镜像使用指南:从入门到实战
运维·docker·容器
YBN娜32 分钟前
设计模式-创建型设计模式
java·开发语言·设计模式
桦说编程1 小时前
CompletableFuture API 过于复杂?选取7个最常用的方法,解决95%的问题
java·后端·函数式编程
Lenyiin1 小时前
《 Linux 点滴漫谈: 三 》掌控终端:让 Shell 成为你的系统魔杖
linux·运维·服务器·lenyiin
杭州泽沃电子科技有限公司1 小时前
钢铁厂运输设备在线监测:构建智能工厂的安全与效率基石
运维·人工智能·智能监测