zoukankan      html  css  js  c++  java
  • nginx集群tomcat,session共享问题

    tomcat-redis-session-manager
    版本: apache-tomcat-8.0.32、nginx-1.13.12、redis_3.2.1

    github地址: https://github.com/mzd123/session_manager 读者可以直接下载体验一下。

    实现:

    1、下载:https://github.com/ran-jit/tomcat-cluster-redis-session-manager/wiki

    2、解压之后。将jar包放入tomcat的lib中(注意是tomcat/lib中,不是我们自己项目的lib)


    3、配置解压之后的redis-data-cache.properties(根据你的redis配置吧)。配置完将这个文件放入tomcat/conf文件夹中。


    4、配置tomcat/cong/context.xml,增加如下两行。

    <WatchedResource>WEB-INF/web.xml</WatchedResource>
    <WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>


    5、注意:因为tomcat-redis-session-manager这个版本的不同,classname会随着变化,2.0.4的版本是叫这两个。其实可以打开你下载的tomcat-cluster-redis-session-manager.jar看看他到底叫什么(不少小伙伴,本人第一次搞也是,网上代码一抄,发现tomcat启动就报类找不到。。。你classname都填错了,当然找不到了,能找到就奇怪了。。。)


    测试:

    1、nginx配置:

    upstream mzd{
    server 127.0.0.1:8091;
    server 127.0.0.1:8090;
    }

    server {
    listen 80;
    server_name www.tuesdayma.com;

    location / {
    proxy_pass http://mzd;
    proxy_connect_timeout 3s;
    proxy_read_timeout 5s;
    proxy_send_timeout 3s;
    index index.html index.htm;
    }
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    root html;
    }


    }

    2、准备两个tomcat,一个端口为8090,一个为8091

    3、tomcat中jsp代码:

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ page language="java" import="java.text.SimpleDateFormat"%>
    <%
    request.getSession().setAttribute("mzd","123");
    SimpleDateFormat simpleDateFormat=new SimpleDateFormat("YYYY-MM-dd HH:mm:ss");
    String date=simpleDateFormat.format(new Date());
    %>

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <title>tomcat1</title>
    </head>
    <body>
    SessionID:<%=session.getId()%>
    当前时间为:<%=date%>
    SessionPort:<%=request.getServerPort()%>
    mzd的值为:<%=session.getAttribute("mzd")%>
    <%
    out.println("这是tomcat1");
    %>
    </body>
    </html>

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ page language="java" import="java.text.SimpleDateFormat"%>
    <%
    SimpleDateFormat simpleDateFormat=new SimpleDateFormat("YYYY-MM-dd HH:mm:ss");
    String date=simpleDateFormat.format(new Date());
    %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <title>tomcat2</title>
    </head>
    <body>
    SessionID:<%=session.getId()%>
    当前时间为:<%=date%>
    SessionPort:<%=request.getServerPort()%>
    mzd的值为:<%=session.getAttribute("mzd")%>
    <%
    out.println("这是tomcat2");
    %>
    </body>
    </html>

    4、启动两个tomcat和redis:如果不启动redis是会报错的。。。

    结果:


    测试结果很明显,sessionid没有改变。而且在tomcat1中设置的mzd值在tomcat2中jsp也能拿到这个值。

    方法四:使用jwt
    原理:放弃session机制,使用jwt机制。简单来说就是userid+随机数+签名加密生成一个token,前后端通信通过token来交互。客户端第一次请求登入之后,服务器端给客户端一个token,服务器将token作为key值,userid作为value值,30分钟作为有效时间存入redis中;客户端第二次访问controller之前进行拦截,判断是否有token,如果有token解密获取userid,然后取查询redis,token和userid是否匹配,如果匹配就允许访问controller,请求返回之后,服务器将重新生成新的token返回给客户端。简单来说就是每次请求成功之后token都会改变,token存在redis中,这样一来至于redis分发到哪个tomat并不影响,因为token是存在redis中的。。。
    ---------------------
    作者:一只仰望天空的菜鸟
    来源:CSDN
    原文:https://blog.csdn.net/tuesdayma/article/details/81387862
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    ☀【布局】
    _#【CSS3】
    _#minheight
    【其它】引入css
    【css3】url
    鼠标闲置一段时间后自动隐藏
    图解SQLServer2005获取WebService数据
    Oracle字符串字段内的字符排序
    一个c#读取扫雷内存的demo
    sqlserver使用bcp分解字符串
  • 原文地址:https://www.cnblogs.com/caozengling/p/10316188.html
Copyright © 2011-2022 走看看