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

Redis 5.0中的 Stream是什么?

Redis Stream 数据结构详解

Redis Stream 是 Redis 5.0 版本引入的新型数据结构,专门用于处理有序、可追溯的消息流。其核心特性包括消息持久化、有序性以及消费者组支持,使其成为构建可靠消息系统的理想选择。

基本概念与特性

Stream 本质上是一个有序消息日志,每条消息都具有唯一 ID 并按添加顺序严格排列。开发者可以执行以下操作:

  • 消息的发布与消费
  • 消息删除管理
  • 实时消息订阅
  • 消费者组协同处理

核心优势(相较于 Pub/Sub)

  1. 消息持久化:克服了传统 Pub/Sub 消息易丢失的缺陷,支持网络中断/服务重启后的数据恢复
  2. 主备复制:确保全时段数据可访问性
  3. 消费位置记忆:精确记录各客户端消费进度

典型应用场景

  • 消息队列系统
  • 实时日志收集
  • 即时数据处理
  • 在线聊天室

核心特性详解

1. 消息有序性

所有消息严格按发布时间排序,消费者按时间顺序处理

2. 多消费者支持

  • 竞争式消费:多个消费者争抢消息处理
  • 共享式消费:消费者协同处理消息流

3. 持久化机制

服务异常重启后仍可完整恢复历史消息

4. 消息分组

通过消费组实现灵活的消息分配策略

实现原理

底层结构

采用类日志的存储方式:

  • 每个 Stream 包含若干日志段
  • 日志段由多个消息组成
  • 消息包含:唯一ID、时间戳、消息体等元数据

关键命令

  • 消息流相关命令(生产者 & 查询)
    命令作用示例
    XADD添加消息XADD mystream * name 张三 age 18
    XTRIM修剪流,限制长度XTRIM mystream MAXLEN 1000
    XDEL删除消息XDEL mystream 1607524047165-0
    XLEN获取消息数量XLEN mystream
    XRANGE获取消息(正向)XRANGE mystream - + COUNT 10
    XREVRANGE获取消息(反向)XREVRANGE mystream + - COUNT 10
    XREAD读取消息(非组方式)XREAD COUNT 10 STREAMS mystream 0

    消费者组相关命令(消费者)
    命令作用示例
    XGROUP CREATE创建消费者组XGROUP CREATE mystream mygroup $ MKSTREAM
    XREADGROUP GROUP消费组读消息XREADGROUP GROUP mygroup c1 STREAMS mystream >
    XACK标记消息已处理XACK mystream mygroup 1607524047165-0
    XGROUP SETID设置起始消费IDXGROUP SETID mystream mygroup 0
    XGROUP DELCONSUMER删除消费者XGROUP DELCONSUMER mystream mygroup c1
    XGROUP DESTROY删除消费者组XGROUP DESTROY mystream mygroup
    XPENDING查看待确认消息XPENDING mystream mygroup
    XCLAIM声明消息归属权(例如超时后转移)XCLAIM mystream mygroup c2 60000 1607524047165-0

    查看信息
    命令作用示例
    XINFO STREAM查看流状态XINFO STREAM mystream
    XINFO GROUPS查看所有消费者组XINFO GROUPS mystream
    XINFO CONSUMERS查看某个组下消费者XINFO CONSUMERS mystream mygroup

工作流程

  1. 消息发布:通过自动生成ID(自然序/UUID)写入日志
  2. 消费处理
    • 消费者通过XREAD(GROUP)获取消息
    • 使用XACK确认处理完成
  3. 消费组协同
    • 组内消费者独立维护消费偏移量
    • 支持消息重投机制处理超时/失败场景
http://www.xdnf.cn/news/1170037.html

相关文章:

  • Vue开发常用库(含npm安装命令)
  • Linux中信号认识及处理和硬件中断与软中断的讲解
  • 设计模式七:抽象工厂模式(Abstract Factory Pattern)
  • el-input 动态获焦
  • An error occurred at line: 1 in the generated java file问题处理及tomcat指定对应的jdk运行
  • 对随机生成的html文件做标签简析
  • Python趣味算法:折半查找(二分查找)算法终极指南——原理、实现与优化
  • Spring 核心知识点梳理 1
  • Jmeter使用 - 2
  • 第十一章 用Java实现JVM之异常处理
  • 使用 Ansys Fluent 软件参数化工作流程对搅拌罐中的稳态涡流进行仿真
  • 质量即服务:从测试策略到平台运营的全链路作战手册
  • 日语学习-日语知识点小记-构建基础-JLPT-N3阶段(7):自動詞 & 他動詞
  • es6中的symbol基础知识
  • Lua语言
  • web登录页面
  • Elasticsearch Java 8.x 的聚合 API 及子聚合的用法
  • 外网访问内部私有局域网方案,解决运营商只分配内网IP不给公网IP问题
  • iOS加固工具有哪些?从零源码到深度混淆的全景解读
  • DearMom以“新生儿安全系统”重塑婴儿车价值,揽获CBME双项大奖
  • vue2.0 + elementui + i18n:实现多语言功能
  • fuse低代码工作流平台概述【已开源】-自研
  • Java中关于线程池的解析
  • Qt 事件处理机制深入剖析
  • 厌氧菌数据挖掘可行性评估报告
  • 深入理解 Qt 中的 QImage 与 QPixmap:底层机制、差异、优化策略全解析
  • PyQt5在Pycharm上的环境搭建 -- Qt Designer + Pyuic + Pyrcc组合,大幅提升GUI开发效率
  • stm32 智能小车
  • [2025CVPR-小目标检测方向]基于特征信息驱动位置高斯分布估计微小目标检测模型
  • AI视频-剧本篇学习笔记