news 2026/5/5 4:56:02

Redis Stream 深入理解:它到底解决了什么问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Redis Stream 深入理解:它到底解决了什么问题

在 Redis 5.0 之前,如果你想用 Redis 做“消息”,基本绕不开 List 或 Pub/Sub。List 可以做阻塞消费,但消息一旦被取走就彻底消失,消费者挂了就是事故;Pub/Sub 更直接,消息不落地,订阅者一掉线,消息就像没发生过一样。这两种模型都不具备可靠消息系统的核心能力:可追溯、可确认、可重试。

Redis Stream 的出现,本质上就是 Redis 官方承认了一件事:Redis 需要一个真正的日志型消息结构

Stream 的核心设计非常像 Kafka:所有消息只追加、不修改,每条消息都有一个全局有序的 ID。这个 ID 由时间戳和序号组成,例如:

1700000000000-0 1700000000000-1

Redis 保证 ID 单调递增,这一点非常关键,因为它让 Stream 天然支持范围查询、顺序消费和断点恢复。

向 Stream 中写入消息使用的是XADD

XADD mystream * user alice action login

*表示让 Redis 自动生成 ID。每条消息不是一个简单字符串,而是一组 field-value,这一点和 List 最大的不同在于:Stream 的 value 是结构化的

真正让 Stream 成为“消息队列”的,并不是 XADD,而是消费组(Consumer Group)。消费组解决的是“同一条消息只能被一个消费者处理,并且必须被确认”。

你可以先创建一个消费组:

XGROUP CREATE mystream group1 0

0表示从头开始消费历史消息。

消费者使用XREADGROUP拉消息:

XREADGROUP GROUP group1 c1 COUNT 1 BLOCK 0 STREAMS mystream >

这里有一个非常容易被忽略但极其重要的点:
当这条消息被投递给消费者c1时,它并没有从 Stream 中删除,而是被放进了消费组的一个结构里,叫PEL(Pending Entries List)

PEL 的含义是:已投递,但尚未确认的消息

只要你没XACK,Redis 就认为这条消息“可能没处理完”。

XACK mystream group1 1700000000000-0

ACK 之后,这条消息才会从 PEL 中移除。但注意:消息本身依然留在 Stream 里,只是这个消费组不再关心它。

PEL 的存在,直接解决了 List 和 Pub/Sub 永远解决不了的问题:
消费者宕机怎么办?

假设消费者c1读到一条消息,还没来得及处理就挂了,这条消息就会一直躺在 PEL 里。你可以通过:

XPENDING mystream group1

看到有哪些“卡住”的消息,然后用:

XCLAIM mystream group1 c2 60000 1700000000000-0

把超过 60 秒没处理的消息,抢给另一个消费者c2
这一套机制,本质上就是 Redis 自己实现的at-least-once 消费模型

从内部实现来看,Stream 并不是一个简单的链表。Redis 使用的是Radix Tree(基数树)来存储消息 ID 和内容,这让它在 ID 有序的前提下,依然可以高效做区间扫描,比如:

XRANGE mystream 1700000000000-0 +

这也是为什么 Stream 可以非常自然地支持“重放历史消息”,而 List 和 Pub/Sub 做不到。

需要注意的是,Stream不会自动删除消息。如果你只消费、不裁剪,Stream 会无限增长:

XTRIM mystream MAXLEN ~ 100000

这里的~是近似裁剪,Redis 会在性能和精确度之间做权衡。

还有一个实践中的坑:PEL 一定要被清理。如果消费者逻辑有问题,消息一直不 ACK,PEL 会越来越大,最后看起来像“没消息可消费”,但实际上全卡在 PEL 里。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 8:11:36

学霸同款10个一键生成论文工具,研究生高效写作必备!

学霸同款10个一键生成论文工具,研究生高效写作必备! AI 工具如何助力论文写作,提升效率与质量 在研究生阶段,论文写作是一项不可避免的任务,而随着人工智能技术的不断进步,AI 工具已经成为许多学生的得力…

作者头像 李华
网站建设 2026/5/1 8:40:09

一个月内面了30家公司,薪资从18K变成28K,真行啊····

工作3年,换了好几份工作(行业流行性大),每次工作都是裸辞。朋友都觉得不可思议。因为我一直对自己很有信心,而且特别不喜欢请假面试,对自己负责也对公司负责。 但是这次没想到市场环境非常不好,…

作者头像 李华
网站建设 2026/5/3 5:29:06

Device (P2P0)下的子节点Device (S7F0)不存在

Device (P2P0)下的子节点Device (S7F0)不存在dsdt.dsl:6096: Device (P2P0) dsdt.dsl:6306: Device (S1F0) dsdt.dsl:6338: Device (S2F0) dsdt.dsl:6370: Device (S3F0) dsdt.dsl:6402: Device (S4F0…

作者头像 李华
网站建设 2026/5/1 17:07:03

OFFSET动态可视化:WPS表格灵活提取多行多列数据

一、问题的提出 日常工作中经常需要从结构化报表中查询并提取特定公司的多期数据。例如:在月度销售报表中,根据公司名称动态返回其1-6月的详细数据。这种需求常见于经营分析、数据看板及报告生成等场景。 假设有一张公司月度数据表,A列为公司…

作者头像 李华