Redisson学习专栏(四):实战应用(分布式会话管理,延迟队列)

article/2025/6/17 11:02:05

文章目录

  • 前言
  • 一、为什么需要分布式会话管理?
    • 1.1 使用 Redisson 实现 Session 共享
  • 二、订单超时未支付?用延迟队列精准处理
    • 2.1 RDelayedQueue 核心机制
    • 2.2 订单超时处理实战
  • 总结


前言

在现代分布式系统中,会话管理和延迟任务处理是两个核心需求。本文将深入探讨如何利用 Redisson 解决这两个问题,通过代码实战演示分布式会话共享和订单超时未支付的延迟任务处理。


一、为什么需要分布式会话管理?

在单机应用中,Session 存储在内存中。但在分布式环境下,请求可能被负载均衡到不同服务器,导致 Session 丢失。解决方案:将会话数据集中存储在 Redis 中,实现多服务共享。

1.1 使用 Redisson 实现 Session 共享

实现原理:
将会话数据存储在 Redis Hash 结构中,利用 Redisson 的分布式对象操作 API 实现透明化存取。
Maven 依赖:

<dependency><groupId>org.redisson</groupId><artifactId>redisson-spring-boot-starter</artifactId><version>3.23.2</version>
</dependency>

配置 Redisson 客户端:

@Configuration
public class RedissonConfig {@Beanpublic RedissonClient redissonClient() {Config config = new Config();config.useSingleServer().setAddress("redis://127.0.0.1:6379");return Redisson.create(config);}
}

会话管理服务:

@Service
public class SessionService {@Autowiredprivate RedissonClient redissonClient;// 存储会话数据public void putSession(String sessionId, String key, Object value) {RMap<String, Object> sessionMap = redissonClient.getMap("session:" + sessionId);sessionMap.put(key, value);// 设置会话过期时间(30分钟)sessionMap.expire(30, TimeUnit.MINUTES);}// 获取会话数据public Object getSession(String sessionId, String key) {RMap<String, Object> sessionMap = redissonClient.getMap("session:" + sessionId);return sessionMap.get(key);}// 销毁会话public void invalidateSession(String sessionId) {redissonClient.getMap("session:" + sessionId).delete();}
}

Controller 中使用示例:

@RestController
public class AuthController {@Autowiredprivate SessionService sessionService;@PostMapping("/login")public String login(@RequestBody User user, HttpServletRequest request) {// 验证用户逻辑...String sessionId = request.getSession().getId();sessionService.putSession(sessionId, "user", user);return "Login success! Session: " + sessionId;}@GetMapping("/profile")public User profile(HttpServletRequest request) {String sessionId = request.getSession().getId();return (User) sessionService.getSession(sessionId, "user");}
}

二、订单超时未支付?用延迟队列精准处理

电商场景中,订单创建后需在 30 分钟内支付,否则自动关闭。传统轮询数据库方案效率低下,Redisson 的 RDelayedQueue 是完美解决方案

2.1 RDelayedQueue 核心机制

RDelayedQueue 核心机制

2.2 订单超时处理实战

订单服务实现:

@Service
public class OrderService {@Autowiredprivate RedissonClient redissonClient;// 创建订单并加入延迟队列public void createOrder(Order order) {// 1. 保存订单到数据库(状态:待支付)orderRepository.save(order);// 2. 加入延迟队列(30分钟超时)RBlockingQueue<String> blockingQueue = redissonClient.getBlockingQueue("ORDER_EXPIRE_QUEUE");RDelayedQueue<String> delayedQueue = redissonClient.getDelayedQueue(blockingQueue);delayedQueue.offer(order.getId(), 30, TimeUnit.MINUTES);}// 监听订单超时队列@PostConstructpublic void startExpireListener() {new Thread(() -> {RBlockingQueue<String> blockingQueue = redissonClient.getBlockingQueue("ORDER_EXPIRE_QUEUE");while (true) {try {String orderId = blockingQueue.take(); // 阻塞获取到期订单handleExpiredOrder(orderId);} catch (InterruptedException e) {Thread.currentThread().interrupt();break;}}}).start();}// 处理过期订单private void handleExpiredOrder(String orderId) {Order order = orderRepository.findById(orderId).orElse(null);if (order != null && "UNPAID".equals(order.getStatus())) {order.setStatus("CANCELED");order.setCancelReason("支付超时");orderRepository.save(order);System.out.println("订单超时关闭: " + orderId);// 释放库存等后续操作...}}
}

支付回调逻辑:

public void onPaymentSuccess(String orderId) {// 1. 更新订单状态为已支付Order order = orderRepository.findById(orderId).get();order.setStatus("PAID");orderRepository.save(order);// 2. 从延迟队列中移除(避免重复处理)RDelayedQueue<String> delayedQueue = redissonClient.getDelayedQueue(redissonClient.getBlockingQueue("ORDER_EXPIRE_QUEUE"));delayedQueue.remove(orderId); // 关键:支付成功则移除任务
}

总结

通过本文实战,我们实现了:

  1. 分布式会话管理:利用 RMap 存储会话数据,解决集群环境 Session 共享问题
  2. 精准延迟任务:基于 RDelayedQueue 实现订单超时自动关闭,替代低效轮询方案

Redisson 的强大之处在于将复杂的分布式问题抽象为简单的 API 调用。这两个方案可扩展到更多场景:

  • 会话管理 → 分布式权限系统
  • 延迟队列 → 定时通知、预约系统

http://www.hkcw.cn/article/HvqYQBYKpj.shtml

相关文章

Cloudini 点云压缩库 ROS PCL 入门教程

系列文章目录 前言 Cloudini 是一个点云压缩库。 它的重点是速度&#xff0c;但仍能达到很好的压缩比。 其主要用途如下 改进包含点云数据的数据集的存储&#xff08;一个显著的例子就是 rosbags&#xff09;。降低在网络上串流点云数据时所使用的带宽。 它可与 PCL 和 ROS 无…

吉林第三届全国龙舟邀请赛(大安站)激情开赛

龙舟竞渡处,瑞气满湖光。5月31日&#xff0c;金蛇献瑞龙舞九州2025年全国龙舟大联动-中国吉林第三届全国龙舟邀请赛(大安站)“嫩江湾杯”白城市全民健身龙舟赛在吉林大安嫩江湾国家5A级旅游区玉龙湖拉开帷幕。 上午9时&#xff0c;伴随着激昂的音乐&#xff0c;活力四射的青春舞…

【NLP 78、手搓Transformer模型结构及实战】

你以为走不出的淤泥&#xff0c;也迟早会云淡风轻 —— 25.5.31 引言 ——《Attention is all you need》 《Attention is all you need》这篇论文可以说是自然语言处理领域的一座里程碑&#xff0c;它提出的 Transformer 结构带来了一场技术革命。 研究背景与目标 在 Transfo…

【深度学习】14. DL在CV中的应用章:目标检测: R-CNN, Fast R-CNN, Faster R-CNN, MASK R-CNN

深度学习在计算机视觉中的应用介绍 深度卷积神经网络&#xff08;Deep convolutional neural network&#xff0c; DCNN&#xff09;是将深度学习引入计算机视觉发展的关键概念。通过模仿生物神经系统&#xff0c;深度神经网络可以提供前所未有的能力来解释复杂的数据模式&…

性能优化 - 理论篇:CPU、内存、I/O诊断手段

文章目录 Pre引言1. CPU 性能瓶颈1.1 top 命令 —— 多维度 CPU 使用率指标1.2 负载&#xff08;load&#xff09;——任务排队情况1.3 vmstat 命令 —— CPU 繁忙与等待 2. 内存性能瓶颈2.1 操作系统层面的内存分布2.2 top 命令 —— VIRT / RES / SHR 三个关键列2.3 CPU 缓存…

javaweb-maven以及http协议

1.maven坐标&#xff1a; 坐标是资源的唯一标识&#xff0c;通过该坐标可以唯一定位资源位置&#xff1b; 2.坐标的组成&#xff1a; groupId:定义当前项目隶书的组织名称&#xff1b; artifactId&#xff1a;定义当前maven项目名称 version&#xff1a;定义项目版本 3.依…

Qq空间照片视频批量下载工具

软件介绍 本文介绍的软件是QQ空间相册批量下载器&#xff0c;专门用于批量下载QQ空间中的照片和视频。 软件背景与需求 作为80、90后一代的集体回忆&#xff0c;QQ空间承载了许多人的青春记忆。然而随着时间推移和设备更新&#xff0c;空间中的照片视频画质逐渐模糊。同时&a…

AI Agent智能体:底层逻辑、原理与大模型关系深度解析·优雅草卓伊凡

AI Agent智能体&#xff1a;底层逻辑、原理与大模型关系深度解析优雅草卓伊凡 一、AI Agent的底层架构与核心原理 1.1 AI Agent的基本构成要素 AI Agent&#xff08;人工智能代理&#xff09;是一种能够感知环境、自主决策并执行行动的智能系统。其核心架构包含以下关键组件…

【GESP真题解析】第 19 集 GESP 二级 2024 年 12 月编程题 2:数位和

大家好,我是莫小特。 这篇文章给大家分享 GESP 二级 2024 年 12 月编程题第 2 题:数位和。 题目链接 洛谷链接:B4065 数位和 一、完成输入 根据输入格式的描述,输入包含一个正整数 n,数据范围: 1 ≤ n ≤ 10 5 1\le n \le 10^5 1≤n≤105,用 int 类型最合适。 int n…

Python趣学篇:交互式词云生成器(jieba + Tkinter + WordCloud等)

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 一、为什么要做词云&#xff1f;让文字"活"起来&#xff01;二、核心…

lstm 长短期记忆 视频截图 kaggle示例

【官方双语】LSTM&#xff08;长短期记忆神经网络&#xff09;最简单清晰的解释来了&#xff01;_哔哩哔哩_bilibili . [short,input]*[2.7,1.63]b5.95 换参数和激活函数 tan激活函数输出带正负符号的百分比 tanx公式长这样&#xff1f; 潜在短期记忆 前几天都是乱预测&#xf…

GD32F103系列工程模版创建记录

准备条件&#xff1a; 1&#xff1a;首先需要下载GD32F103的官方库 2&#xff1a;GD32F103的软件包 3&#xff1a;KEIL5软件 4&#xff1a;单片机GD32F103C8T6 本文已经默认KEIL5已将安装好GD32F103的软件包了 步骤一 基本模版创建 1 打开KEIL5软件&#xff0c;新建工程&am…

火绒 6.0 全家桶合集 - 绿色单文件提取版 (垃圾清理/右键管理/弹窗拦截等)

软件介绍 作为互联网冲浪选手&#xff0c;想必火绒是绝大多数网友电脑必备软件之一&#xff0c;今天给大家带来的是我自己用了很久的版本。 软件特点 免费、功能还不错&#xff0c;解压就可以用 软件使用 本次火绒6.0小工具独立版&#xff0c;一共提取了10种小工具&#xf…

守护生命之光:进行性核上性麻痹的全方位健康护理指南

进行性核上性麻痹&#xff08;PSP&#xff09;是一种罕见的神经退行性疾病&#xff0c;主要影响患者的运动、平衡及吞咽等功能。科学的健康护理能有效延缓病情发展&#xff0c;提升患者生活质量&#xff0c;具体可从以下方面开展。 在日常生活护理中&#xff0c;安全防护至关重…

聊一下AI编程领域的最新进展

引子 最近&#xff0c;我收听了多个 AI 编程相关的播客&#xff0c;从中捕捉到了一些显著趋势。同时&#xff0c;我还深入研读了 Cursor、Windsurf、Trae 等相关创始人的访谈&#xff0c;广泛涉猎了 AI 编程领域的大量信息&#xff0c;并进行了深入的反思与总结。在此&#xf…

【Doris基础】Doris中的Replica详解:Replica原理、架构

目录 1 Replica基础概念 1.1 什么是Replica 1.2 Doris中的副本类型 2 Doris副本架构设计 2.1 副本分布机制 2.2 副本一致性模型 3 副本生命周期管理 3.1 副本创建流程 3.2 副本恢复机制 4 副本读写流程详解 4.1 写入流程与副本同步 4.2 查询流程与副本选择 5 副本…

老主板焕新生-技嘉B250M-DS3H开Above 4G(G4560+外置核显DG1)

DG1显卡 Intel DG1显卡是一款基于Xe-LP架构的入门级独立显卡&#xff0c;以下是其优势和特点&#xff0c;以及对于老主板&#xff08;10代CPU以前&#xff09;的优势&#xff1a; 优势和特点: 视频编解码能力强&#xff1a;DG1显卡支持多种视频格式的编解码&#xff0c;包括H.…

4.6 linux内核启动分析

1. Linux内核源码目录结构 目录名称作用arch包含了不同架构相关的代码block块设备相关的源代码crypto加密算法相关的源代码drivers包含了系统中设备驱动的源代码firmware一些固件的源代码fs系统支持的文件系统相关的源代码include内核共用的头文件init内核启动的源代码ipc进程…

Oracle中EXISTS NOT EXISTS的使用

目录 1.IN与EXISTS EXISTS用法总结 2.NOT IN与NOT EXISTS 3.not in 中 null的用法 4.EXISTS和IN的区别 (面试常问) 1.IN与EXISTS 示例&#xff1a;在 DEPT 表中找出在 EMP 表中存在的部门编号&#xff1b; 方法一&#xff1a;使用in select DEPTNO from DEPT where D…

Lyra学习笔记 Experience流程梳理

目录 前言1 创建2 加载3 Deactivate4 总结与图示 前言 这篇主要将视角放在Experience的流程&#xff0c;所以不会涉及一些更深的东西 之后ULyraExperienceManagerComponent简称为EMC 1 创建 完事开头难&#xff0c;首先找到了管理Experience的组件&#xff0c;那么它的初始化…