跳到主要内容

打造高性能的RedisStream队列

RedisStream特点

Redis Stream 5.x 版本引入的一种数据结构,用于处理时间序列数据、消息队列和日志流。它提供了高吞吐量、持久性、有序、可扩展的消息传递解决方案,并提供了以下主要特性:

  • 多生产者和多消费者: 多个生产者可以同时向 Stream 中写入消息,而多个消费者可以独立订阅并消费消息。每个消费者可以有不同的消费速率。
  • 消费组: Redis Stream引入了消费者组的概念,多个消费者可以加入同一个消费者组并共同消费消息,这确保了消息在消费时不会被多次处理。
  • 消费者阻塞: 消费者可以使用 XREADGROUP 命令以阻塞方式获取消息,只有当有新消息到达时才会被推送给消费者。
  • 消费者自动确认: Redis Stream 支持自动确认消息,消费者可以告诉 Redis 何时确认已经成功处理了一条消息。
  • 多 Stream 支持: 你可以创建多个 Stream 来存储不同种类的数据,并分别处理它们。
  • 有序性: 消息在 Stream 中按照消息的时间戳有序存储,因此你可以按照消息的顺序读取数据。
  • 持久性存储: Redis Stream 使用内存数据结构,但也支持将数据异步保存到磁盘,以确保数据不会丢失。

然而在 SpringBoot 中操作 RedisStream 还是比较复杂的,需要配置消息的发送、序列化、消息的监听配置、拉取时间、消息类型等等,还有各种繁琐的api操作

所以针对上述问题,本人设计了 RedisStream 的组件,使用此组件操作 RedisStream 会变得非常的简单,默认情况下无需考虑上述配置的细节问题,下面就来介绍此组件的设计原理

使用

依赖

<dependency>
<groupId>com.example</groupId>
<artifactId>damai-redis-stream-framework</artifactId>
<version>${revision}</version>
</dependency>

配置信息

spring:
data:
# redis配置
redis:
database: 0
host: 127.0.0.1
port: 6379
timeout: 3000
# redisStream配置
stream:
# stream名字
streamName: test_stream
# 消费组名字
consumerGroup: test_group
# 消费者名
consumerName: test_consumer_1
# 消费方式 group:消费组(默认)/broadcast:广播
consumerType: group

付费内容提示

该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放

加入星球后,你可以获得:

  • 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
  • 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
  • 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
  • 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠