当前位置: 首页 > article >正文

基于Redis 的分布式 session 图解

Redis 分布式 Session 工作原理

1. 传统 Session 的问题

在传统单服务器环境中,HTTP Session 存储在应用服务器的内存中。这在分布式系统中会导致问题:

  • 用户的请求可能被分发到不同服务器,导致会话不一致
  • 服务器宕机会导致会话丢失
  • 需要依赖负载均衡器的会话粘性(sticky session)机制,限制了系统的伸缩性

2. Spring Session + Redis 解决方案

当配置了Spring Session + Redis后,系统会:

  1. 拦截请求处理流程

    • Spring Session 使用一个过滤器(SpringSessionRepositoryFilter)拦截所有HTTP请求
    • 这个过滤器由DelegatingFilterProxy代理,在Spring Boot应用中自动配置
  2. 替换原生Session实现

    • 过滤器会将容器原生的HttpSession实现替换为Spring自定义的实现
    • 所有对HttpSession的操作实际上都被Spring Session接管
  3. Session数据外部化

    • 所有会话数据存储在Redis中,而非应用服务器内存
    • 客户端仍然通过Cookie接收会话ID
    • 服务器使用该ID从Redis中检索完整的会话数据

3. Redis 存储格式

Redis中的几个关键数据结构:

  • Strings类型spring:session:sessions:expires:{sessionId} - 用于跟踪会话过期
  • Hash表类型spring:session:sessions:{sessionId} - 存储实际的会话数据
  • Sets类型spring:session:expirations:{timestamp} - 用于管理会话的过期机制

4. 请求处理流程

  1. 请求到达

    • 客户端发送请求,包含sessionID的Cookie
    • Spring Session过滤器拦截请求
  2. 会话检索

    • 从Cookie中提取sessionID
    • 使用该ID从Redis查询会话数据
    • 创建包含该数据的会话对象
  3. 请求处理

    • 应用程序使用该会话对象,仿佛它是标准的HttpSession
    • 对会话的任何修改都被跟踪
  4. 请求完成

    • 如果会话数据被修改,更新存储在Redis中的数据
    • 如有必要,更新过期时间

5. 技术亮点

  • 无侵入性:应用代码不需要任何改变,正常使用HttpSession接口
  • 无需会话粘性:负载均衡器不再需要配置sticky session
  • 弹性伸缩:服务器可以随时添加或移除,不影响用户会话
  • 容错性:单个服务器故障不会导致用户会话丢失
  • 集中管理:会话数据集中存储,便于监控和管理

这种设计使得Spring应用可以在分布式环境中无缝扩展,同时保持用户会话的连续性和一致性,是微服务架构中解决用户状态管理的优雅方案。
在这里插入图片描述

  1. 客户端先 带着 HTTP 请求到 负载均衡器
  2. 负载均衡器 转发请求到应用服务器
  3. 被SpringSessionFiliter 拦截
  4. 从 Cookie 中提取 SessionID
    • 如果 该sessionID 存在,通过 该sessionID 从 SessionRespository 获取会话, SessionRespository 查询 Redis 中的 会话数量,RedisOperations 给Redis 服务器发送了 GET spring:session:sessions:{sessionId}。Redis 给 RedisOperations 返回数据。最终在 SessionRespository 构建请求对象给 SpringSessionFiliter

    • 如果 该sessionID 不存在或者过期,那么 SpringSessionFiliter 给 SessionRepository 创建新的会话。sessionRepository 在 Redis 中创建新会话,

      • Strings类型:spring:session:sessions:expires:{sessionId} - 用于跟踪会话过期
      • Hash表类型:spring:session:sessions:{sessionId} - 存储实际的会话数据
      • Sets类型:spring:session:expirations:{timestamp} - 用于管理会话的过期机制

      创建完成后,返回 新的session 对象给 SpringSessionFiliter

业务处理中可能发生修改 会话数量,如果有 SpringSessionFiliter 调用 SessionRepository 保存会话的变更,更新Redis 中的会话数量, HMSET 更新 会话数量,重置过期时间。

Mermind 绘图代码:

sequenceDiagramparticipant C as 客户端participant LB as 负载均衡器participant F as SpringSessionFilterparticipant S as SessionRepositoryparticipant R as RedisOperationsparticipant RD as Redis服务器C->>LB: 1. HTTP请求(带SessionID Cookie)LB->>F: 2. 转发请求到应用服务器F->>F: 3. 拦截请求F->>F: 4. 从Cookie中提取SessionIDalt 存在SessionIDF->>S: 5a. 通过SessionID获取会话S->>R: 6a. 查询Redis中的会话数据R->>RD: 7a. GET spring:session:sessions:{sessionId}RD-->>R: 8a. 返回会话数据R-->>S: 9a. 返回会话数据S-->>F: 10a. 构建Session对象else 不存在SessionID或会话已过期F->>S: 5b. 创建新会话S->>R: 6b. 在Redis中创建新会话R->>RD: 7b. HMSET spring:session:sessions:{newId}R->>RD: 8b. SET spring:session:sessions:expires:{newId}R->>RD: 9b. SADD spring:session:expirations:{expireTime}RD-->>R: 10b. 确认创建成功R-->>S: 11b. 返回新会话IDS-->>F: 12b. 返回新Session对象endF->>+S: 13. 包装为SessionRepositoryRequestWrapperS->>-F: 14. 返回包装后的请求对象F->>F: 15. 继续请求处理链Note over F,S: 业务逻辑处理期间可能会修改会话数据F->>S: 16. 保存会话变更(如有)S->>R: 17. 更新Redis中的会话数据R->>RD: 18. HMSET 更新会话数据R->>RD: 19. 重置过期时间F->>LB: 20. 返回HTTP响应LB->>C: 21. 转发响应

相关文章:

基于Redis 的分布式 session 图解

Redis 分布式 Session 工作原理 1. 传统 Session 的问题 在传统单服务器环境中,HTTP Session 存储在应用服务器的内存中。这在分布式系统中会导致问题: 用户的请求可能被分发到不同服务器,导致会话不一致服务器宕机会导致会话丢失需要依赖…...

Vue进阶之AI智能助手项目(四)——ChatGPT的调用和开发

AI智能助手项目 前端接口部分src/api/index.tssrc/utils/request/index.tspost方法httpHttpOptionsrc/utils/request/axios.tsLayout布局页面-viewsexception异常页面src/views/exception/404/index.vuesrc/views/exception/500/index.vueLayout布局页面src/views/chat/layout/…...

DeepSeek-R1本地部署保姆级教程

一、DeepSeek-R1本地部署配置要求 (一)轻量级模型 ▌DeepSeek-R1-1.5B 内存容量:≥8GB 显卡需求:支持CPU推理(无需独立GPU) 适用场景:本地环境验证测试/Ollama集成调试 (二&a…...

【deepseek】本地部署+webui访问

背景 最近deepseek很火,但是官网的老是被限流使用,还有就是自己也想着玩一玩,于是准备在自己电脑跑一个 直接附上结果地址mydeepseek 准备工作 windows和linux都可 我这里选择linux,ubuntu系统 安装ollama 看下图&#xff0…...

deepseek部署:ELK + Filebeat + Zookeeper + Kafka

## 1. 概述 本文档旨在指导如何在7台机器上部署ELK(Elasticsearch, Logstash, Kibana)堆栈、Filebeat、Zookeeper和Kafka。该部署方案适用于日志收集、处理和可视化场景。 ## 2. 环境准备 ### 2.1 机器分配 | 机器编号 | 主机名 | IP地址 | 部署组件 |-…...

博客系统笔记总结 2( Linux 相关)

Linux 基本使用和程序部署 基本命令 文件操作 显示当前目录下的文件 ls:显示当前目录下的文件 ll:以列表的形式展示,包括隐藏文件 进入目录 && 显示当前路径 cd:进入目录(后面跟相对路径或者绝对路径&…...

Flutter - 基础Widget

Flutter 中万物皆 Widget,基础Widget 同步对应 Android View. 普通文本 Text /*** 控制文本样式统一使用 style:TextStyle, 例:fontSize(字体大小),color(颜色),shadows(阴影)等等* 控制文本布局需单独设置:* textAlign(文不对齐方式)* te…...

如何在 Linux 上安装和配置 Zsh

文章目录 如何在 Linux 上安装和配置 Zsh1. 安装 Zsh1.1 在 Ubuntu/Debian 上安装1.2 在 CentOS/RHEL/Fedora 上安装1.3 在 Arch Linux 上安装1.4 验证 Zsh 安装 2. 设置 Zsh 为默认 Shell2.1 验证默认 shell 3. 配置 Zsh3.1 使用 Oh My Zsh3.1.1 安装 Oh My Zsh3.1.2 启用插件…...

【System Verilog and UVM基础入门26】Verdi使用教程指南

《Verdi使用教程指南 》 下载链接: https://download.csdn.net/download/TommiWei/90429701https://download.csdn.net/download/TommiWei/90429701 朋友你好,不管你是否使用过Verdi这款EDA仿真工具。 不管你是否还在寻找免费的使用教材。 不管你是否…...

3dtiles平移旋转工具制作

3dtiles平移旋转缩放原理及可视化工具实现 背景 平时工作中,通过cesium平台来搭建一个演示场景是很常见的事情。一般来说,演示场景不需要多完善的功能,但是需要一批三维模型搭建,如厂房、电力设备、园区等。在实际搭建过程中&…...

【STL专题】优先级队列priority_queue的使用和模拟实现,巧妙利用仿函数解决优先级

欢迎来到 CILMY23的博客 🏆本篇主题为:优先级队列priority_queue的使用和模拟实现,巧妙利用仿函数解决优先级 🏆个人主页:CILMY23-CSDN博客 🏆系列专栏: C | C语言 | 数据结构与算法 | Linux…...

数据开发面试:DQL,

DQL常见面试题 where 和 having 的区别 三个排序开窗函数的区别 left join 用where 筛选 和 用on筛选的区别 ON 子句:用于定义连接条件,不会丢失左表的行。 WHERE 子句:用于过滤连接后的结果集,可能会丢失左表中没有匹配的行 …...

学习Flask:Day 2:模板与表单开发

学习目标:前后端混合开发 # 添加模板渲染 from flask import render_templateapp.route(/profile) def profile():return render_template(profile.html, username"开发者",skills[Vue, JavaScript]) ✅ 实践任务: 创建templates目录 使用J…...

最长递增子序列(贪心算法)思路+源码

文章目录 题目[](https://leetcode.cn/problems/longest-increasing-subsequence/)算法原理源码总结题目 首先,要掌握动态规划加二分查找 算法原理 1.回顾dp的解法 状态表示:dp[i]表示:以i位置的元素为结尾的所有的子序列中,最长递增子序列的长度 状态转移方程:dp[i]= m…...

Orange 开源项目 - 集成百度智能云-千帆大模型

1 集成百度智能云-千帆大模型 百度智能云-千帆ModelBuilder百度智能云千帆大模型服务与开发平台ModelBuilder(以下简称千帆ModelBuilder)是面向企业开发者的一站式大模型开发及服务运行平台。千帆ModelBuilder不仅提供了包括文心一言底层模型和第三方开源…...

前缀和代码解析

前缀和是指数组一定范围的数的总和,常见的有两种,一维和二维,我会用两道题来分别解析 一维 DP34 【模板】前缀和 题目: 题目解析: 暴力解法 直接遍历数组,遍历到下标为 l 时,开始进行相加,直到遍历到下标为 r ,最后返回总和.这样做的时间复杂度为: O(n) public class Main …...

C 语言结构体:从入门到进阶的全面解析

一、结构体类型的声明 1.1 结构的声明 结构体是一种自定义的数据类型,允许将不同类型的数据组合成一个整体。声明语法如下: struct 结构体名 {数据类型 成员1;数据类型 成员2;// ... }; 示例: struct Student {char name[20];int age;fl…...

交换机与路由器连接方式

交换机和路由器连接的三种主要方式如下: 一、直连连接 这是最简单直接的连接方式。通过一根网线将交换机的一个端口与路由器的一个LAN端口相连。这种连接方式适用于小型网络,其中交换机负责局域网内部的数据交换,而路由器则负责将内部网络连接…...

自适应增强技术

1. 传统图像处理中的自适应增强&#xff08;如CLAHE&#xff09; 难度&#xff1a;⭐容易 实现方式&#xff1a;调用成熟的库&#xff08;如OpenCV&#xff09;函数即可完成。 示例代码&#xff08;CLAHE增强&#xff09;&#xff1a; <PYTHON> import cv2# 输入灰度或彩…...

【前端基础】Day 1 HTML

总结&#xff1a; 1. Web标准的构成 2. 基本标签 目录 1. Web标准的构成 2. 基本标签 2.1快捷键 2.2.1标题标签 2.2.2段落和换行标签 2.2.3文本格式化标签 2.2.4div和span标签 2.3.1 图像标签和路径 2.3.2路径 2.3.3超链接标签 2.4注释标签 2.5特殊字符 1. Web标准…...

【前端基础】Day 2 HTML

目录 1.表格标签 2.列表标签 3.表单标签 4.综合案例 5.查阅文档 1.表格标签 <body><table align"center" border"1" cellpadding"0" cellspacing"0" width"500" height"100"><thead> …...

Docker run --add-host参数解析(在容器启动时向/etc/hosts文件中添加自定义的主机名与IP映射)(适用于临时调试或测试)

文章目录 Docker run --add-host 参数解析一、参数概述二、工作原理三、应用场景1. **开发与调试**2. **环境隔离**3. **跨网络访问** 四、使用示例示例 1&#xff1a;单个自定义映射示例 2&#xff1a;多个映射同时使用 五、注意事项六、总结 Docker run --add-host 参数解析 …...

电商网站如何解决高并发问题

电商网站如何解决高并发问题&#xff1f;当下电商行业蓬勃发展&#xff0c;电商网站面临的用户访问量和高并发问题日益严峻。在电商大促、节日促销等关键时期&#xff0c;如何确保网站稳定运行&#xff0c;提升用户体验&#xff0c;成为了电商企业亟需解决的问题。小编推荐大家…...

MySQL 入门“鸡”础

一、Win10 与Ubuntu安装 以下是一篇针对 Ubuntu 安装 MySQL 的过程中写的示例&#xff1a; --- # Ubuntu 安装 MySQL 详细指南 在本教程中&#xff0c;我们将向您展示如何在 Ubuntu 上安装 MySQL&#xff0c;并完成基本的安全配置。以下是具体步骤&#xff1a; # 1. 安装 …...

若依前后端分离框架修改3.8.9版本(重点在安全框架讲解与微信小程序登录集成)

若依模板改造&#xff08;3.8.9&#xff09; 1、基础改造 下载代码 从[RuoYi-Vue: &#x1f389; 基于SpringBoot&#xff0c;Spring Security&#xff0c;JWT&#xff0c;Vue & Element 的前后端分离权限管理系统&#xff0c;同时提供了 Vue3 的版本](https://gitee.co…...

selenium爬取苏宁易购平台某产品的评论

目录 selenium的介绍 1、 selenium是什么&#xff1f; 2、selenium的工作原理 3、如何使用selenium&#xff1f; webdriver浏览器驱动设置 关键步骤 代码 运行结果 注意事项 selenium的介绍 1、 selenium是什么&#xff1f; 用于Web应用程序测试的工具。可以驱动浏览…...

kubernetes-完美下载

话不多说&#xff0c;直接开始从0搭建k8s集群 环境&#xff1a;centous7.9 2核 20G k8s-master 192.168.37.20 k8s-node1 192.168.37.21 k8s-node2 192.168.37.22 一&#xff1a;设置主机名 #设置主机名 hostnamectl set-hostname k8s-master hostnamectl set-h…...

PostgreSQL 常用函数

PostgreSQL 常用函数 在数据库管理系统中&#xff0c;函数是执行特定任务的基本构建块。PostgreSQL 是一个功能强大的开源关系数据库管理系统&#xff0c;提供了丰富的内置函数&#xff0c;这些函数极大地增强了数据库操作的能力。以下是一些在 PostgreSQL 中常用的函数&#…...

【初阶数据结构】树和二叉树

目录 前言树的概念与结构树的概念树的相关概念树的表示 二叉树的概念及结构二叉树的概念几种特殊的二叉树1.满二叉树2.完全二叉树 二叉树的性质二叉树的存储结构1、顺序存储2、链式存储 前言 前面我们学习了顺序表&#xff0c;单链表&#xff0c;栈和队列&#xff0c;它们在逻…...

【中等】59.螺旋矩阵Ⅱ

题目描述 给你一个正整数 n &#xff0c;生成一个包含 1 到 n2 所有元素&#xff0c;且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;[[1,2,3],[8,9,4],[7,6,5]]示例 2&#xff1a; 输入&#xff1a;n…...