session共享问题及四种解决方案-前端存储、session的复制 、session粘性、后端存储(Mysql、Redis等)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: session共享问题及解决方案

tomcat的安装与配置


tomcat的安装

官网下载

Apache Tomcat官网

我下载的版本为8.5.82

7e354ff584b74ca780399b8490b042ca.png

解压两份

a97adaace08743d0be95900e6825f518.png

tomcat集群的配置


官网提供的配置f1a3242f29d94d73a7d2977f528b8433.png7d23fc889de94f8b96035ffc52eac3aa.pngfda2f588963f4ee99b4b239b97ed1607.png

官网配置地址

c560ac8546ee42b494d6b0fe1545a807.png

我的配置步骤

  <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
                 channelSendOptions="8">
          <Manager className="org.apache.catalina.ha.session.DeltaManager"
                   expireSessionsOnShutdown="false"
                   notifyListenersOnReplication="true"/>
          <Channel className="org.apache.catalina.tribes.group.GroupChannel">
            <Membership className="org.apache.catalina.tribes.membership.McastService"
                        address="228.0.0.4"
                        port="45564"
                        frequency="500"
                        dropTime="3000"/>
            <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
                      address="auto"
                      port="4000"
                      autoBind="100"
                      selectorTimeout="5000"
                      maxThreads="6"/>
            <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
              <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
            </Sender>
            <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
            <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatchInterceptor"/>
          </Channel>
          <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
                 filter=""/>
          <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
          <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
                    tempDir="/tmp/war-temp/"
                    deployDir="/tmp/war-deploy/"
                    watchDir="/tmp/war-listen/"
                    watchEnabled="false"/>
          <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
        </Cluster>

1、将上面的复制到两个tomcat的server.xml配置文件中

aadbe1a6fd1b44af81387a16dd4c32ea.png

2、改端口

为啥改端口:因为我只有一台电脑


只要不与tomcat1相同就行

f1a3242f29d94d73a7d2977f528b8433.png7d23fc889de94f8b96035ffc52eac3aa.pngfda2f588963f4ee99b4b239b97ed1607.png


3、在tomcat1和tomcat2中的webapps\ROOT目录下删除页面然后加上这三个页面


第一个是index,第二个是login,第三个是logout

index是首页,login是设置session,logout是删除session

把tomcat2改为tomcat1然后继续复制

80ccadf49bc94ffcaf21987bfa22fb3f.png

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
    <head>
  <title>
  tomcat2
  </title>
  </head>
    <body>
        SessionID:<%=session.getId()%>
    <br>
        SessionValue:<%=session.getAttribute("session")%>
        <br>
    SessionIP:<%=request.getServerName()%>
        <br>
    SessionPort:<%=request.getServerPort()%>
    <br>
        <%
            out.println("this is tomcat 2");
        %>
    </body>
</html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
    <head>
  <title>
  tomcat2
  </title>
  </head>
    <body>
        <%
      session.setAttribute("session","libo");
    %>
        <%
            out.println("this is set SessionValue success");
        %>
    </body>
</html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
    <head>
  <title>
  tomcat2
  </title>
  </head>
    <body>
        <%
      session.removeAttribute("session");
    %>
        <%
            out.println("this is remove SessionValue success");
        %>
    </body>
</html>


session问题解决方法


前端存储

原理

每次前端发请求时候都把这个携带走

4909059c93fb438baa6d6a29cd5169ca (1).png

优缺点

优点

不占用服务端内存


缺点

存在安全风险

数据大小受cookie限制

占用外网宽带


session的复制

操作步骤

在每个tomcat 的 “webapps\ROOT\WEB-INF\web.xml” 里面加上 distributable标签

e51cf65ffef444be8e9ced407ab2c1b3.png

都没有登录05d7e0229a36468592abd08f23b5fbbe.png

tomcat1登录

a464ebfd58334b6b8ed5e1334fbad6a6.png

tomcat2查看是否可以获取数据

获取成功8d8ea8de9d134fb49f244b64d6312564.png


tomcat1退出

b528729fd1b44e7a99ffd50325cc17be.png

tomcat2查看是否可以获取数据

获取不到了,因为session是共享,已经在tomcat1那里退出登录了

495cf848e3b9456f84ef728bcbc72a3e.png

原理

多个server之间相互同步session,这样每个server之间都包含全部的session

631068384eea4249a46d73f3b50066b4.png

优缺点

优点

1、只需要设定配置,应用程序不需要修改代码

2、有一台机器挂了,其他机器还保存有


缺点

1、ession的同步需要数据传输,占内网带宽,有延时

2、所有server都包含所有session数据,数据量受最小内存的sever限制


session粘性

操作步骤

下载安装nginx

官网下载,我是已经下载过的了

CSDN博客找篇按照下载


配置nginx.conf

这样就会轮询两个tomcat服务器

e4c36920337b481b80d4e519695e53d3.png

把刚才tomcat里面的web.xml去掉distributable标签

访问localhost然后就会一直是一个tomcate21a730aafb5413b85cba7c32e902bdb (1).png

注意

fc05d8db557f41cba5be75bd7f26a312.png

原理

可以通过某种形式,将用户的每次请求都固定到某一台机器上。例如通过Nginx的ip_hash策略进行负载均衡,只要用户的IP固定不变,总能访问到同一台服务器上

b57e19917ee54ea3b9ba346b23fee7b8.png

优缺点

优点

无需修改代码

服务端可以水平扩展


缺点

如果某台服务器挂掉了,Session就会丢失

如果一个局域网内大量用户那么也没啥用了(使用默认的ip_hash算法)


后端存储(Mysql、Redis等)

原理都是一样的,但是如果要是海量请求同时发送,请求数据库,容易造成数据库的压力过大从而崩溃,所以我们演示是基于Redis

操作步骤

访问我仓库下载代码

点击进入

原理

传统模式中,当request进入web容器,根据request获取session时,如果容器内存在session则返回,如果不存在就创建一个session然后返回,将sessionId返回

后端存储就是将session从容器里面抽出来,形成独立的模块,以便分布式或者集群能够共享。当request进入容器时,根据request获取session时,去找redis如果存在就返回,如果不存在就创建并存储

239d9b23b77846f18c0c6ac41974b255.png

优缺点

优点

代码灵活,对web容器无侵入

速度比mysql更快


缺点

需要编写代码


239d9b23b77846f18c0c6ac41974b255.png239d9b23b77846f18c0c6ac41974b255.png

相关文章
|
3月前
|
存储 NoSQL 前端开发
Redis专题-实战篇一-基于Session和Redis实现登录业务
本项目基于SpringBoot实现黑马点评系统,涵盖Session与Redis两种登录方案。通过验证码登录、用户信息存储、拦截器校验等流程,解决集群环境下Session不共享问题,采用Redis替代Session实现数据共享与自动续期,提升系统可扩展性与安全性。
242 3
Redis专题-实战篇一-基于Session和Redis实现登录业务
|
11月前
|
SQL 关系型数据库 MySQL
网安入门之MySQL后端基础
《网安入门之MySQL后端基础》简介: 本文介绍了数据库及MySQL的基础知识,涵盖数据库的概念、结构与操作。数据库是组织化存储数据的集合,通过表、列、行等结构实现高效管理。MySQL作为开源的关系型数据库管理系统,广泛应用于Web开发。文中详细讲解了MySQL的基本操作,如增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)等语句的使用方法,并介绍了数据库事务的ACID特性。此外,还探讨了SQL注入攻击的风险及防范措施,强调了预处理语句的重要性。最后,简述了PHP中mysqli扩展的使用方法,包括连接数据库、执行查询和关闭连接等步骤。
|
7月前
|
Java 关系型数据库 MySQL
在Linux平台上进行JDK、Tomcat、MySQL的安装并部署后端项目
现在,你可以通过访问http://Your_IP:Tomcat_Port/Your_Project访问你的项目了。如果一切顺利,你将看到那绚烂的胜利之光照耀在你的项目之上!
393 41
|
7月前
|
开发框架 Java 关系型数据库
在Linux系统中安装JDK、Tomcat、MySQL以及部署J2EE后端接口
校验时,浏览器输入:http://[your_server_IP]:8080/myapp。如果你看到你的应用的欢迎页面,恭喜你,一切都已就绪。
511 17
|
7月前
|
Java 关系型数据库 MySQL
在Linux操作系统上设置JDK、Tomcat、MySQL以及J2EE后端接口的部署步骤
让我们总结一下,给你的Linux操作系统装备上最强的军队,需要先后装备好JDK的弓箭,布置好Tomcat的阵地,再把MySQL的物资原料准备好,最后部署好J2EE攻城车,那就准备好进军吧,你的Linux军团,无人可挡!
160 18
|
7月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
464 11
|
7月前
|
开发框架 关系型数据库 Java
Linux操作系统中JDK、Tomcat、MySQL的完整安装流程以及J2EE后端接口的部署
然后Tomcat会自动将其解压成一个名为ROOT的文件夹。重启Tomcat,让新“植物”适应新环境。访问http://localhost:8080/yourproject看到你的项目页面,说明“植物”种植成功。
223 10
|
存储 缓存 前端开发
Django 后端架构开发:存储层调优策略解析
Django 后端架构开发:存储层调优策略解析
311 2
|
JavaScript NoSQL Redis
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
这篇文章记录了在Vue中实现修改手机号和邮箱的大致流程,包括使用过滤器部分隐藏展示的手机号和邮箱,以及通过点击触发路由跳转的便捷方式。文章还描述了旧号码和新号码验证的界面实现,其中验证码由后端生成并通过弹窗展示给用户,未来可以接入真正的手机验证码接口。此外,还提供了修改邮箱的页面效果截图,并强调了学习是一个永无止境的过程。
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
|
12月前
|
安全 Java API
实现跨域请求:Spring Boot后端的解决方案
本文介绍了在Spring Boot中处理跨域请求的三种方法:使用`@CrossOrigin`注解、全局配置以及自定义过滤器。每种方法都适用于不同的场景和需求,帮助开发者灵活地解决跨域问题,确保前后端交互顺畅与安全。
1580 0

热门文章

最新文章

  • 1
    前端工程化演进之路:从手工作坊到AI驱动的智能化开发
  • 2
    Vue 3 + TypeScript 现代前端开发最佳实践(2025版指南)
  • 3
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
  • 推荐镜像

    更多