zoukankan      html  css  js  c++  java
  • 负载均衡下 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共享。

  • 相关阅读:
    Office 2010激活 NO KMS products detected问题
    强制换行/不换行 (兼容IE)
    el-radio再次点击取消选中
    几个 JavaScript 实用小技巧
    微信小程序-点击事件传递参数
    微信小程序-存取本地缓存
    微信小程序-路由方式
    element-ui 表格排序失效
    watch监听(数组或者对象)
    vue 引入 base64或者md5对密码进行加密
  • 原文地址:https://www.cnblogs.com/yg_zhang/p/10198003.html
Copyright © 2011-2022 走看看