Redis 消息队列和发布订阅

本文详细介绍了Redis中实现消息队列的三种模式:生产者消费者、发布者订阅者以及Stream模式。内容包括各模式的原理、模型、Redis与Java的实现方法,以及选型指导。Redis Stream作为5.0新增的数据结构,提供了消息持久化和主备复制功能,适合轻量级MQ需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基本模式

采用redis
三种方案:
● 生产者消费者:一个消息只能有一个消费者
● 发布者订阅者:一个消息可以被多个消费者收到
● stream模式:实现队列和广播模式

生产者消费者

原理&模型

在这里插入图片描述

Producer调用redis的lpush往特定key里放消息,Consumer调用brpop去不断监听key。

1、利用redis的链表,存储数据,实现队列模式
2、生产者左进,消费者右出
3、消费者,线程拉取数据模式

redis实现

10.255.20.232:1>lpush test_mq 'lwd'
"1"
10.255.20.232:1>lpush test_mq 'lwd2'
"2"
10.255.20.232:1>lpush test_mq 'lwd3'
"3"
10.255.20.232:1>lrange test_mq 0 10
1) "lwd3"
2) "lwd2"
3) "lwd"

10.255.20.232:1>brpop test_mq 0
1) "test_mq"
2) "lwd"

10.255.20.232:1>lrange test_mq 0 10
1) "lwd3"
2) "lwd2"

java实现

//producer
String key="demo:mq:test";
String msg="hello world";
redisDao.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南巷Dong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值