Redis 非缓存核心场景及实例说明

Redis 非缓存核心场景及实例说明

一、分布式锁

分布式锁用于解决分布式系统中多节点竞争同一资源的问题,确保操作原子性。Redis 实现分布式锁的核心思路是利用键的唯一性和原子命令,通常基于 Redisson 框架简化实现(底层依赖 Redis 命令)。

实例:电商秒杀场景中防止库存超卖。假设某商品库存为 100 件,多台应用服务器同时处理用户抢购请求,需通过分布式锁保证“查库存-扣库存”操作的原子性。

  1. 应用节点通过 Redisson 获取锁:RLock lock = redisson.getLock("seckill:lock:goodsId123"),底层会执行 SET seckill:lock:goodsId123 value NX PX 30000(NX 表示键不存在时才创建,PX 表示设置 30 秒过期时间,避免死锁)。
  2. 获取锁成功后,查询 Redis 中的商品库存:GET goods:stock:123,若库存 > 0,则执行扣库存操作:DECR goods:stock:123
  3. 操作完成后释放锁:lock.unlock(),底层会删除锁键。若节点意外宕机,锁键会因过期时间自动删除,避免长期占用锁资源。

二、限流

限流用于控制单位时间内接口的请求次数,防止系统因高并发过载。Redis 通常结合 Lua 脚本或 Redisson 实现,常见算法有令牌桶、漏桶等,Redisson 的 RRateLimiter 封装了限流逻辑,底层依赖 Redis 数据结构和 Lua 脚本保证原子性。

实例:API 接口限流,限制单个用户每分钟最多发起 60 次请求(即每秒 1 次)。

  1. 使用 Redisson 创建限流器:RRateLimiter limiter = redisson.getRateLimiter("api:limiter:userId456"),设置限流规则:limiter.trySetRate(RateType.PER_USER, 60, 1, RateIntervalUnit.MINUTES)(表示每个用户每分钟最多 60 次请求)。
  2. 每次用户发起请求前,调用 boolean allowed = limiter.tryAcquire(1)(尝试获取 1 个“令牌”)。若返回 true,则允许请求;若返回 false,则拒绝请求并返回“请求过于频繁”。
  3. 底层通过 Redis 的 zset 存储请求时间戳,结合 Lua 脚本计算单位时间内的请求次数,确保限流逻辑的原子性和准确性,避免多节点计数偏差。

三、消息队列

Redis 可通过 List、Pub/Sub、Stream 三种方式实现消息队列,其中 Stream 是 Redis 5.0 新增的专门用于消息队列的数据结构,支持持久化、ACK 机制、消费组等特性,解决了 List 和 Pub/Sub 的消息丢失、堆积问题。

实例:订单状态变更通知,当订单从“待支付”变为“已支付”时,需通知库存系统扣减库存、通知物流系统创建物流单。

  1. 生产者(订单系统)向 Stream 发送消息:XADD order:status:stream * orderId 789 status PAID* 表示由 Redis 生成唯一消息 ID,包含时间戳和序列号;orderIdstatus 是消息内容)。
  2. 消费者组(库存系统、物流系统)创建并订阅 Stream:先创建消费组 XGROUP CREATE order:status:stream group:stock 00 表示从最早的消息开始消费),再通过 XREADGROUP GROUP group:stock consumer:stock 0 COUNT 1 BLOCK 0 STREAMS order:status:stream > 阻塞读取消息(> 表示读取未被消费的消息)。
  3. 消费者处理完消息后,发送 ACK 确认:XACK order:status:stream group:stock 消息ID,标记消息已处理,避免重复消费。若消费者宕机,未 ACK 的消息会留在“挂起队列”,其他消费者可通过 XPENDING 查询并重新处理,保证消息不丢失。

四、延时队列

延时队列用于处理“延迟执行”的任务,如订单超时未支付自动取消、红包 24 小时未领取自动退还。Redis 实现延时队列的主流方式是 Redisson 的 RDelayedQueue,底层基于 zset 存储任务(以“任务执行时间戳”为分数),结合定时任务扫描到期任务。

实例:订单超时未支付自动取消,设置订单创建后 30 分钟未支付则取消。

  1. 创建 Redisson 客户端并初始化延时队列:RBlockingQueue<String> blockingQueue = redisson.getBlockingQueue("order:delay:queue"); RDelayedQueue<String> delayedQueue = redisson.getDelayedQueue(blockingQueue);
  2. 订单创建时,将订单 ID 放入延时队列并设置延迟时间:delayedQueue.offer("orderId789", 30, TimeUnit.MINUTES)(表示 30 分钟后该订单 ID 会被放入阻塞队列)。
  3. 消费者(订单处理系统)启动线程,通过 String orderId = blockingQueue.take() 阻塞获取到期的订单 ID,然后执行取消逻辑(如更新订单状态为“已取消”、恢复商品库存)。
  4. 底层通过 zset 存储订单 ID 和到期时间戳,Redisson 后台线程定期扫描 zset,将分数(到期时间戳)小于当前时间的任务移动到阻塞队列,实现延时触发。同时,Redis 持久化机制(RDB/AOF)确保任务在 Redis 宕机后不丢失,重启后可继续执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/96146.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/96146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【技术教程】如何将ONLYOFFICE文档集成到使用Spring Boot框架编写的Java Web应用程序中

在现代协作办公环境中&#xff0c;将功能强大的文档编辑器无缝集成到自有业务系统中&#xff0c;已成为提升工作效率和用户体验的关键需求。ONLYOFFICE 文档服务器提供了一套成熟的在线文档编辑解决方案&#xff0c;而 Java Spring Boot 则是构建高效、模块化 Web 应用的热门框…

openharmony之AV_CodeC音视频编解码模块详解(二)

1. 音频解码器函数调用流程 1.1 音频解码器架构概览 decoder:解码器 encoder:编码器 前面文章介绍了关于openHarmony的AV_CodeC模块,这篇文章将详细讲解编解码时函数的调用流程 音频解码器采用插件化架构,核心实现位于: services/engine/codec/audio/decoder/audio_ffmpeg…

PDF24 Creator:免费的多功能PDF工具

在处理PDF文件时&#xff0c;一个功能强大且免费的PDF工具是许多用户的首选。PDF24 Creator作为一款免费的PDF工具&#xff0c;提供了丰富的功能&#xff0c;帮助用户创建、编辑和转换PDF文件&#xff0c;满足从初学者到专业用户的各种需求。它不仅支持PDF与Word、Excel等15种以…

VBA 中使用 ADODB 操作 SQLite 插入中文乱码问题

问题 使用 VBA 的 ADODB 对象的 command 对象、parameter 对象&#xff0c;插入的中文数据为乱码 驱动下载、安装、引用 驱动网址(下载路径) 使用的 ODBC 驱动&#xff08;需要梯子才能下载&#xff0c;感谢大佬开源&#xff09; http://www.ch-werner.de/sqliteodbc/ 版本…

执行select * from a where rownum<1;,数据库子进程崩溃,业务中断。

文章目录环境症状触发条件解决方案环境 系统平台&#xff1a;Linux x86-64 Red Hat Enterprise Linux 7 版本&#xff1a;4.5.2 症状 执行select * from a where rownum<1;&#xff0c;数据库子进程崩溃&#xff0c;业务中断。 触发条件 select 和 where条件带有rownum…

python库 Py2app 的详细使用(将 Python 脚本变为 MacOS 独立软件包)

更多内容请见: python3案例和总结-专栏介绍和目录 文章目录 一、Py2app 概述 1.1 Py2app 介绍 1.2 安装 1.3 替代工具推荐 二、基础使用 2.1 最简单的 setup.py 文件 2.2 完整示例 2.3 配置选项详解 2.4 完整项目案例 2.5 打包为单文件应用(可选) 三、高级配置 3.1 处理特定…

NTP配置为客户端广播监听模式

前言 项目需求&#xff1a; 使能ntp为客户端模式&#xff0c;能监服务端广播模式发出的ntp报文&#xff0c;计算出服务端的时间与客户端的时间偏差并上报。 开发状况&#xff1a; 交叉编译ntp源码&#xff0c;将修改后的ntpd进程部署到设备上作为客户端完成项目需求 如何操作&a…

Claude-Flow 使用指南

Claude-Flow 不仅仅是一个工具&#xff0c;更是一个强大的AI驱动开发编排平台。本问初步带您深入了解 Claude-Flow v2.0.0 Alpha 的强大功能&#xff0c;助您在AI开发领域如虎添翼。1. 简介&#xff1a;什么是 Claude-Flow&#xff1f; Claude-Flow v2 Alpha 是一个企业级的AI编…

系统梳理 Test-Time Compute 的主要实现路径

编者按&#xff1a; AI 真的在“思考”吗&#xff1f;当模型面对数学推理、代码生成或复杂决策时&#xff0c;它是如何一步步推演出答案的&#xff1f;如果你曾困惑于大模型在关键任务中表现不稳定、缺乏可解释性&#xff0c;甚至生成结果难以验证&#xff0c;那么你并不孤单。…

vue 经常写的echarts图表模块结构抽取

vue 经常写的echarts图表模块结构抽取将项目中经常写的结构抽取一下, 方便以后用 表头包含标题和右侧操作部分下面为图表 <div class"chartBox"><div class"chartheadbox"><div class"chartheadleft">这是图表标题</div>…

主流的开源协议(MIT,Apache,GPL v2/v3)

文章目录1. MIT 协议 (MIT License)2. Apache 2.0 协议 (Apache License 2.0)3. GPL v2 协议 (GNU General Public License v2)“开源协议选择指南”的流程图 flowchart TDA[开始选择开源协议] --> B{是否要求修改后必须开源?<br>(是否具有 传染性?)};B -- 是&…

CameraService笔记

cameraservicecamera 结构图1. 启动CameraServer1.1 注册media.camera服务1.2 构造CameraService1.3 CameraService::onFirstRef1.4 CameraService::enumerateProviders&#xff1a;前置准备知识1.4 CameraService::enumerateProviders&#xff1a;Provider和Device初始化1.4.1…

MacOS 15.6 编译SDL3 Android平台多架构so库

成功编译输出: 编译: Android平台多架构编译脚本: sdl3_android_build.sh #!/bin/bash# 设置变量 macos 其他系统需要更改路径 SDL_SOURCE_DIR=$(pwd)/SDL BUILD_DIR=${SDL_SOURCE_DIR}/../sdl3_build_android NDK_PATH=$HOME/Library/Android/Sdk/Ndk/25.2.9519653 CMAKE…

Real-IAD D³: A Real-World 2D/Pseudo-3D/3D Dataset for Industrial Anomaly

Real-IAD D: A Real-World 2D/Pseudo-3D/3D Dataset for Industrial Anomaly Detection Paper Github 摘要 随着工业异常检测&#xff08;Industrial Anomaly Detection, IAD&#xff09;复杂程度的不断提升&#xff0c;多模态检测方法已成为机器视觉领域的研究焦点。然而&a…

IT需求提示未读信息查询:深度技术解析与性能优化指南【类似:钉钉已读 功能】

IT需求提示未读信息查询&#xff1a;深度技术解析与性能优化指南【类似&#xff1a;钉钉已读 功能】 DROP TABLE IF EXISTS rs_kpi_it_need_tip; CREATE TABLE IF NOT EXISTS rs_kpi_it_need_tip (id bigint NOT NULL AUTO_INCREMENT COMMENT 主键ID&#xff…

Django中的软删除

软删除&#xff08;Soft Delete&#xff09;是一种数据删除策略&#xff0c;它并不真正从数据库中删除记录&#xff0c;而是通过标记&#xff08;如 is_deleted 字段&#xff09;来表示记录已被删除。 这样做的好处是可以保留数据历史&#xff0c;支持数据恢复和审计。 在 Djan…

JavaEE 进阶第四期:开启前端入门之旅(四)

专栏&#xff1a;JavaEE 进阶跃迁营 个人主页&#xff1a;手握风云 目录 一、常用CSS 1.1. border 1.2. width/height 1.3. padding&#xff1a;内边距 1.4. margin&#xff1a;外边距 二、初始JavaScript 2.1. JavaScript是什么 2.2. 发展历史 2.3. JavaScript 和 HT…

学习日记-SpringMVC-day49-9.4

知识点&#xff1a;1.RequestMapping&#xff08;3&#xff09;知识点核心内容重点RequestMapping注解的parameters属性通过parameters指定请求参数条件&#xff08;如bookID&#xff09;&#xff0c;控制请求匹配规则&#xff08;必须包含/排除特定参数或值&#xff09;参数存…

【Day 50 】Linux-nginx反向代理与负载均衡

概述在现代 Web 架构中&#xff0c;Nginx 作为高并发、高性能的 HTTP 和反向代理服务器&#xff0c;被广泛应用于提升服务性能、增强系统安全性和实现负载均衡。其中&#xff0c;反向代理能够隐藏后端服务器信息并优化请求处理流程&#xff0c;负载均衡则可将请求分发到多个后端…

vue中配置 ts

在 Vue 项目中配置 TypeScript&#xff08;TS&#xff09;可以提升代码的类型安全性和开发体验。以下是在 Vue 项目&#xff08;基于 Vite&#xff09;中配置 TypeScript 的详细步骤和关键配置&#xff1a; 一、创建支持 TypeScript 的 Vue 项目 如果是新建项目&#xff0c;推…