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

Redis 实现消息队列

一、为什么选择 Redis 作为消息队列?

在分布式系统架构中,消息队列是实现异步通信和解耦的核心组件。Redis 作为一个高性能的内存数据库,凭借其卓越的速度和丰富的数据结构,成为轻量级消息队列的理想选择:

1.1 核心优势

  • 超高性能:10万+ QPS 的处理能力

  • 毫秒级延迟:内存操作带来的极致响应速度

  • 丰富数据结构:多种队列实现模式可选

  • 零外部依赖:无需额外中间件,降低运维复杂度

  • 持久化支持:可配置持久化保证消息可靠性

1.2 典型应用场景

  • 应用解耦:服务间异步通信

  • 流量削峰:应对突发请求

  • 任务调度:后台任务处理

  • 实时通知:事件驱动架构

  • 日志收集:分布式日志处理

二、Redis 消息队列的三种实现模式

2.1 List 实现:简单队列

数据结构

LPUSH orders:queue "order_data"  # 生产者入队
RPOP orders:queue               # 消费者出队

工作流程: 

特点

  • 先进先出(FIFO)模型

  • 支持阻塞读取(BRPOP/BLPOP)

  • 简单易用但功能有限

2.2 Pub/Sub 实现:发布订阅

核心命令

# 消费者订阅频道
SUBSCRIBE notifications# 生产者发布消息
PUBLISH notifications "New event!"

 拓扑结构

[生产者] --PUBLISH--> [Redis] --推送--> [消费者1]
                         |
                         +--推送--> [消费者2]

适用场景

  • 实时消息广播

  • 事件通知系统

  • 聊天室应用

局限性

  • 消息不持久化

  • 无消息堆积能力

  • 无消费者状态跟踪

2.3 Stream 实现:专业级队列(Redis 5.0+)

现代解决方案

# 生产者添加消息
XADD orders * user_id 1001 product "Laptop"# 消费者组读取
XGROUP CREATE orders order-group $ 
XREADGROUP GROUP order-group consumer1 COUNT 1 STREAMS orders >

核心优势

  • 消息持久化存储

  • 消费者组负载均衡

  • 消息确认机制(ACK)

  • 消息回溯能力

三、Stream 实现详解:生产级消息队列

3.1 数据结构解析

每条消息包含:

{"id": "1662345678900-0",  // 毫秒时间戳-序列号"fields": {"key1": "value1", "key2": "value2"}
}

 3.2 消费者组工作流程

3.3 关键操作命令

生产者操作:
# 添加消息
XADD orders * user_id 1001 action "purchase" amount 299.99# 批量添加(Pipeline)
MULTI
XADD orders * msg "Task1"
XADD orders * msg "Task2"
EXEC

 消费者操作:

# 创建消费者组
XGROUP CREATE orders order-group $# 消费者读取消息
XREADGROUP GROUP order-group consumer1 COUNT 5 BLOCK 10000 STREAMS orders ># 确认消息处理完成
XACK orders order-group 1662345678900-0# 处理失败时重试
XCLAIM orders order-group consumer2 60000 1662345678900-0

http://www.dtcms.com/a/263426.html

相关文章:

  • 【软考高项论文】论信息系统项目的质量管理
  • js代码01
  • 【数据分析】环境数据降维与聚类分析教程:从PCA到可视化
  • uniapp+vue2 input不显示明文密码,点击小眼睛显示或隐藏密码
  • “对象创建”模式之原型模式
  • window显示驱动开发—全屏模式
  • SuperGlue:基于图神经网络的特征匹配技术解析
  • 【Linux系统部分】在Linux命令行中写一个简单的shell外壳
  • ansible的剧本文件一般放在什么地方?
  • creo 2.0学习笔记
  • Stanford_CS224W----Machine learning with graph
  • (5)pytest-yield操作
  • 实现ModbusTCP转Profinet网关协议转换功能的网关设备
  • 【python】langgraph环境安装的曲折办法
  • 问题分解提示法:用结构化方法破解LLM复杂任务难题
  • 信创项目oracle数据库迁移到达梦数据库需要会有哪些问题?如何解决?
  • 《Redis可扩展:轻松应对数据增长与流量高峰》
  • Python 数据分析与机器学习入门 (六):Seaborn 可视化技巧,图表更美观
  • 飞算 JavaAI 深度实战:从老项目重构到全栈开发的降本增效密码
  • Windows如何安装beego环境问题解
  • 正交视图三维重建2 笔记 2d线到3d线2 先生成3d线然后判断3d线在不在
  • 推进自动驾驶车辆智能:基于深度学习和多模态LLM的交通标志识别与鲁棒车道检测
  • 告别复杂爬虫!Perplexity AI辅助Python网页抓取
  • 爬虫详解:Aipy打造自动抓取代理工具
  • Day113 切换Node.js版本、多数据源配置
  • RHCSA认证题目练习一(配置网络设置)
  • Centos7在yum当中遇到Could not resolve host: mirrorlist.centos.org解决方案
  • 高效读取文件中指定行段的两种方法
  • Golang 标准库errors用法
  • Golang快速开发框架——项目立项与系统配置读取组件viper(一)