负载均衡下 tomcat session 共享
Posted 自由港
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了负载均衡下 tomcat session 共享相关的知识,希望对你有一定的参考价值。
概述
在分布式部署的情况下,每台tomcat 都会有自己的session ,这样如果 用户A 在tomcat1 下登录,在tomcat2 下并没有session信息。如果
tomcat1宕机,tomcat2 将会变成非登录状态。可以将tomcat的session信息放到 redis上,通过redis统一管理,因为 tomcat1.tomcat2 都在
同一个域名下面,那么即使tomcat1宕机,tomcat 2 还是可以保持登录状态。
部署步骤
1.使用 nginx 配置好负载均衡。
部署两个tomcat,版本为 tomcat8.5
2.将 以下几个 jar包放到 tomcat的lib目录下。
3.在tomcat 的 conf 目录下
编辑 context.xml
<?xml version="1.0" encoding="UTF-8"?> <Context> <WatchedResource>WEB-INF/web.xml</WatchedResource> <WatchedResource>${catalina.base}/conf/web.xml</WatchedResource> <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" host="localhost" port="6379" database="0" maxInactiveInterval="60" /> </Context>
host port 是 redis 的端口。
4.测试
在tomcat A
ROOT编写一个测试session.jsp 文件
A
<%
out.println( session.getId());
%>
在tomatB ROOT 编写session.jsp
内容如下:
B
<%
out.println( session.getId());
%>
测试效果:
可以看到在两个服务器下 他们的sessionid 是一致的,也就是实现了 通过 redis实现session共享。
以上是关于负载均衡下 tomcat session 共享的主要内容,如果未能解决你的问题,请参考以下文章
nginx-tomcat负载均衡redis-session共享,静态资源分离
转载tomcat+nginx+redis实现均衡负载session共享
Nginx+Tomcat+Memcache实现负载均衡及Session共享
nginx+tomcat实现负载均衡以及session共享(linux centos7环境)