谈一谈分布式会话

一、什么是会话

会话Session代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。曾经的Servlet时代(jsp)),一旦用户与服务端交互,服务器tomcat就会为用户创建一个session,同时前端会有一个jsessionid,每次交互都会携带。如此一来,服务器只要在接到用户请求时候,就可以拿到jsessionid,并根据这个ID在内存中找到对应的会话session,当拿到session会话后,那么我们就可以操作会话了。会话存活期间,我们就能认为用户一直处于正在使用着网站的状态,一旦session超期过时,那么就可以认为用户已经离开网站,停止交互了。用户的身份信息,我们也是通过session来判断的,在session中可以保存不同用户的信息。session的使用之前在单体部分演示过,代码如下∶

@GetMapping("/setSession")
public Object setSession(HttpServletRequest request) {
    HttpSession session = request.getSession();
    session.setAttribute("userInfo","new user");
    session.setMaxInactiveInterval(3600);
    session.getAttribute("userInfo");
    // session.removeAttribute("userInfo");
    return "ok";
}

二、无状态会话

HTTP请求是无状态的,用户向服务端发起多个请求,服务端并不会知道这多次请求都是来自同一用户,这个就是无状态的。cookie 的出现就是为了有状态的记录用户。
常见的,ios与服务端交互,安卓与服务端交互,前后端分离,小程序与服务端交互,他们都是通过发起http来调用接口数据的,每次交互服务端都不会拿到客户端的状态,但是我们可以通过手段去处理,比如每次用户发起请求的时候携带一个userid或者user-token,如此一来,就能让服务端根据用户id或token来获得相应的数据。每个用户的下一次请求都能被服务端识别来自同一个用户。

三、有状态会话

Tomcat中的会话,就是有状态的,一旦用户和服务端交互,就有会话,会话保存了用户的信息,这样用户就”有状态”了,服务端会和每个客户端都保持着这样的一层关系,这个由容器来管理(也就是tomcat),这个session会话是保存到内存空间里的,如此一来,当不同的用户访问服务端,那么就能通过会话知道谁是谁了。tomcat 会话的出现也是为了让http请求变的有状态。如果用户不再和服务端交互,那么会话超时则消失,结束了他的生命周期。如此一来,每个用户其实都会有一个会话被维护,这就是有状态会话。
场景∶在传统项目或者jsp项目中是使用的最多的session都是有状态的,session的存在就是为了弥补http的无状态。

  • 注∶tomcat会话可以通过手段实现多系统之间的状态同步,但是会损耗一定的时间,一旦发生同步那么用户请求就会等待,这种做法不可取。

五、单Tomcat会话(图)

先来看一下单个tomcat会话,这个就是有状态的,用户首次访问服务端,这个时候会话产生,并且会设置jsessionid放入cookie中,后续每次请求都会携带jsessionid以保持用户状态。

谈一谈分布式会话

六、动静分离会话(图)

用户请求服务端,由于动静分离,前端发起http请求,不会携带任何状态,当用户第一次请求以后,我们手动设置一个token,作为用户会话,放入redis中,如此作为redis-session,并且这个token设置后放入前端cookie中(app或小程序可以放入本地缓存),如此后续交互过程中,前端只需要传递token给后端,后端就能识别这个用户请求来自谁了。

谈一谈分布式会话

七、集群分布式系统会话(图)

集群或分布式系统本质都是多个系统,假设这个里有两个服务器节点,分别是AB系统,他们可以是集群,也可以是分布式系统,一开始用户和A系统交互,那么这个时候的用户状态,我们可以保存到redis中,作为A系统的会话信息,随后用户的请求进入到了B系统,那么B系统中的会话我也同样和redis关联,如此AB系统的session就统一了。当然cookie是会随着用户的访问携带过来的。那么这个其实就是分布式会话,通过redis来保存用户的状态。

谈一谈分布式会话

八、类似关系∶局部变量与全局变量

Tomcat会话相当于一个类中某个方法的局部变量,只能在当前方法中使用;分布式会话相当于一个类中的公用全局变量,可以被类中诸多方法使用。如下代码∶

public class DistributedClusterTest {

    public String distributedSession ="global-1001";

    public void userSystem() {
        String userSession = "user-2001";

        System.out.println(distributedSession);
        System.out.printLn(orderSession);
    }

    public void orderSystem() {
        String orderSession = "order-3001";

        System.out.println(distributedSession);
        System.out.println(userSession);
    }
}

distributedSession是这个类中的全局变量,可以在其他的方法中被使用到,而 userSessionorderSession 是在方法中的局部变量,局部变量只能在本方法中使用,全局变量可以在其他方法里都能使用。那么分布式会话和单个tomcat会话其实也是一样的道理。

Original: https://www.cnblogs.com/reminis/p/16265294.html
Author: 小懒编程日记
Title: 谈一谈分布式会话

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/571470/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • MCU软件最佳实践——矩阵键盘驱动

    1.矩阵键盘vs独立按键 在mcu应用开发过程中,独立按键比较常见,但是在需要的按键数比较多时,使用矩阵键盘则可以减少io占用,提高系统资源利用率。例如,某mcu项目要求有16个按…

    Java 2023年6月6日
    060
  • 函数式数据结构-列表

    在开始之前我们先了解几个名词: 1、什么是函数式编程:函数式编程属于”结构化编程”的一种,主要思想是把运算过程尽量写成一系列嵌套的函数调用,可以说是面向过程…

    Java 2023年6月9日
    063
  • idea使用教程-常用设置

    【1】进入设置: 【2】设置主题: 【3】编辑区的字体变大或者变小: 【4】鼠标悬浮在代码上有提示: 【5】自动导包和优化多余的包:手动导包:快捷键:alt+enter自动导包和优…

    Java 2023年6月5日
    074
  • nmap的简单使用

    nmap的简单使用 nmap xxx.xxx.xx.xx 直接扫描 nmap -sS -sV -T4 xxx.xxx.xx.xx -sS 使用TCP SYN扫描 -sV 进行版本检…

    Java 2023年6月7日
    073
  • 深入MySQL(一):MySQL的组织架构

    今天开始将自己所学过的MySQL的知识都尝试融会贯通,并且用写博客的方式记录分享下来。今天讲的主题是 MySQL的组织架构,对于学习一个中间件或者开源项目而言,我觉得最重要的便是先…

    Java 2023年6月7日
    090
  • SpringBoot Maven不自动下载问题

    通过我海明哥解决的,他加了红色字体部分 就搞定了 Original: https://www.cnblogs.com/gjths/p/13806869.htmlAuthor: Ex…

    Java 2023年6月13日
    079
  • 1小时搭建全栈Web应用框架,支持二次开发,随时更新扩展

    现在越来越多的公司企业选择自主开发SaaS软件、OA工作流办公自动化体系、企业信息数据处理运用平台以及许多各种各样的业务流程管理系统。但如何选择一个合适好用的开发框架又成了他们的一…

    Java 2023年6月5日
    080
  • 基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v6.9.0版)

    TableGo_20200520 v6.9.0 正式版发布,此次版本更新如下:1、新增对JDK9及以上版本Java环境的支持2、生成JavaBean更名为生成数据模型并且提供了C#…

    Java 2023年6月9日
    071
  • 和朱晔一起复习Java并发(四):Atomic

    本节我们来研究下并发包中的Atomic类型。 AtomicXXX和XXXAdder以及XXXAccumulator性能测试 先来一把性能测试,对比一下AtomicLong(1.5出…

    Java 2023年5月29日
    063
  • java学习-动手动脑

    public static void main(String[] args) { int x = 100; int y = 200; System.out.println(&quo…

    Java 2023年6月9日
    068
  • 【手把手】光说不练假把式,这篇全链路压测实践探索

    Hello,大家好呀,前两篇文章,我们说了下关于全链路压测的意义、整体架构,以及5种压测的方案。 前面两篇基本都属于比较理论的内容,今天这篇咱们来点实践的东西,手把手带你搞出一个压…

    Java 2023年6月15日
    094
  • Elasticsearch—DSL搜索实践

    POST http://192.168.2.223:9200/shop/_mapping { "properties": { "id": {…

    Java 2023年6月13日
    075
  • 如何使用原生的Feign

    什么是Feign Feign 是由 Netflix 团队开发的一款基于 Java 实现的 HTTP client,借鉴了 Retrofit、 JAXRS-2.0、WebSocket…

    Java 2023年6月14日
    073
  • [spring]spring详细总结

    spring 1.spring简介 Spring框架是一个开源的应用程序框架,是针对bean的生命周期进行管理的轻量级容器。 Spring解决了开发者在J2EE开发中遇到的许多常见…

    Java 2023年6月6日
    086
  • mybatis返回自增主键踩坑记

    背景 MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可…

    Java 2023年5月30日
    076
  • Java 加载动态库 dll 文件

    不知道具体原理,但是,加载 dll 文件时,带路径或者更改 dll 文件的名字,都会报错。虽然库记载成功了,但是处女座认为这不可接受。于是有了这个解决方案。 在根目录为库创建软连接…

    Java 2023年5月29日
    069
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球