码迷,mamicode.com
首页 > 其他好文 > 详细

负载均衡下 tomcat session 共享

时间:2018-12-29 23:27:31      阅读:252      评论:0      收藏:0      [点我收藏+]

标签:.com   bubuko   效果   XML   text   version   edr   hand   分享   

 概述

在分布式部署的情况下,每台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 共享

标签:.com   bubuko   效果   XML   text   version   edr   hand   分享   

原文地址:https://www.cnblogs.com/yg_zhang/p/10198003.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!