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

#Redis黑马点评#(六)Redis当中的消息队列

目录

Redis当中的消息队列

一 基于List

二 基于PubSub

三 基于Stream

单消费模式

消费者组


Redis当中的消息队列

消息队列,字面意思就是存放消息的队列。最简单的消息队列模型包括3个角色:

  • 消息队列:存储和管理消息,也称为消息代理。
  • 生产者:发送消息到消息队列。
  • 消费者:从消息队列获取消息并处理消息。

一 基于List

底层是队列queue的形式

实现方式

  • 生产者:使用 LPUSH 或 RPUSH 将消息写入队列。

  • 消费者:使用 RPOP 或 BLPOP(阻塞式弹出)从队列中读取消息。

优点

  1. 简单高效:性能高,适合简单场景。

  2. 阻塞模式:支持 BLPOP/BRPOP 避免轮询浪费资源。

  3. 持久化:结合 Redis 的持久化机制(RDB/AOF),消息可持久化。

缺点

  1. 消息可靠性不足:消息被 RPOP 后即从队列删除,若消费者处理失败,消息会丢失。

    • 改进方案:使用 RPOPLPUSH 将消息转移到“处理中队列”,处理完成后再删除。

  2. 不支持多消费者:一条消息只能被一个消费者消费。

二 基于PubSub

原理
Redis 的发布订阅(PubSub)模式支持消息的 广播机制,生产者发布消息,所有订阅该频道的消费者都会收到消息。

实现方式

  • 生产者:通过 PUBLISH 向频道发送消息。

  • 消费者:通过 SUBSCRIBE 订阅频道,或 PSUBSCRIBE 订阅模式匹配的频道。

优点

  1. 实时广播:支持一对多消息分发。

  2. 轻量级:实现简单,无需维护消息存储。

缺点

  1. 消息不可靠:无持久化机制,若消费者不在线,消息会丢失。

  2. 无消息堆积能力:无法缓存历史消息。

  3. 不支持消费者组:无法实现负载均衡。

三 基于Stream

原理
Redis 5.0 引入的 Stream 数据结构,提供类似 Kafka 的 持久化日志队列 功能,支持消费者组、消息确认、消息回溯等高级特性。

常用命令

命令作用示例
XADD添加消息XADD mystream * field1 value1 field2 value2
XREAD读取消息XREAD COUNT 2 STREAMS mystream 0
XRANGE按范围查询消息XRANGE mystream - +(全部消息)
XGROUP管理消费者组XGROUP CREATE mystream mygroup 0
XACK确认消息处理完成XACK mystream mygroup 1526919030474-0
XCLAIM重新分配未确认的消息XCLAIM mystream mygroup consumer2 3600000 1526919030474-0

单消费模式

添加消息

读取消息

消费者组

概念:将多个消费者划分到一个组当中,监听同一个队列。

实现步骤:

1 创建消费者组

ID代表从队列的什么地方开始,如果队列当中原始的消息你不想获取你就可使用$符实现对最新的消息进行读取,如果你还需要获取就是用0从队列的第一个消息获取

2 消费者读取消息

0可以获取在pending-List未被确认的消息

一个组内一个进度,1被a读到,那b再接着读就会读到2。

读取消息后还需要确认,这些被读取到的内容还在Pending-List当中,读了就进pending list,然后没xack确认就一直呆在pending-list

3 确认消息

4 其他常见命令

相关文章:

  • k8s备份namespace
  • 多模态信息提取:打通数据价值的“最后一公里”
  • TDengine 在新能源领域的价值
  • 限流算法 + dfa敏感词过滤算法
  • MATLAB中的Switch语句讲解
  • 基于matlab/simulink锂电池算法学习集合(SOC、SOH、BMS)
  • React Flow 边的基础知识与示例:从基本属性到代码实例详解
  • LLM笔记(九)KV缓存调研
  • std::is_same
  • 5月18总结
  • leetcode报错原因总结需要背下来的程序片 [更新中]
  • 三:操作系统线程管理之线程概念
  • 2025年全国青少年信息素养大赛C++小学全年级初赛试题
  • 逻辑与非逻辑的弥聚
  • 【Linux】第二十章 管理基本存储
  • 双紫擒龙紫紫红指标源码学习,2025升级版紫紫红指标公式-重点技术
  • 基于单片机路灯自动控制仪仿真设计
  • 创建型:工厂方法模式
  • TASK03【Datawhale 组队学习】搭建向量知识库
  • 10.9 LangChain LCEL革命:43%性能提升+声明式语法,AI开发效率飙升实战指南
  • 国家统计局:下阶段要继续发挥宏观政策作用,促进价格合理回升
  • 沧州盐碱地“逆天改命”:无用之地变良田,候鸟翔集水草丰美
  • 北斗系统全面进入11个国际组织的标准体系
  • “南昌航空一号”成功发射,赣江鄱阳湖有了专属卫星守护
  • 光速晋级!2025年多哈世乒赛孙颖莎4比0战胜对手
  • 被围观的“英之园”,谁建了潮汕天价违建?