Redis 的发布/订阅模式

Redis的发布/订阅模式比Kafka简单,通过Channel实现。订阅者可以订阅不存在的频道,发布者发送的消息会自动推送给订阅者,但新订阅者无法收到历史消息。关键命令包括subscribe、unsubscribe、publish、psubscribe、punsubscribe,以及pubsubchannels和psubscribe用于查看系统状态和订阅模式。通过示例展示了如何在不同终端订阅和发布消息。

1. 描述

Redis 的发布/订阅模式较 Kafka 等简单很多;

Redis 通过 Channal 实现发布-订阅,订阅者可以对频道进行订阅(不存在的频道将创建频道),发布者向频道发送的消息会自动推送到订阅者端,先发送的消息,后订阅的订阅者是收不到之前的消息的;

2. 相关命令

命令

说明

subscribe channel [channel ...]

订阅给定的一个或多个频道

unsubscribe channel [channel ...]

退订给定的频道

说明:若没有指定 channel,则默认退订所有频道

publish channel message

将消息发送给指定频道 channel

返回结果:接收到信息的订阅者数量,无订阅者返回 0

pubsub channels [argument [argument ...]]

查看订阅与发布系统的状态

说明:返回活跃频道列表(即至少有一个订阅者的频道,订阅模式的客户端除外)

psubscribe pattern1 [pattern ...]

订阅一个或多个符合给定模式的频道

说明:每个模式以 * 作为匹配符;例如 channel* 匹配所有 channel 开头的频道,如:channel1、channel.sub1

punsubscribe [pattern [pattern ...]]

退订所有给定模式的频道

说明:pattern 未指定,则订阅的所有模式都会被退订,否则只退订指定的订阅的模式

3. 实例

创建 5 个终端 shell 窗口,分别运行 redis-cli 客户端;

终端2:

订阅频道 channel1、channel2、channel3,因为频道不存在,因此会自动创建这 3 个频道;

127.0.0.1:6379> subscribe channel1 channel2 channel3

Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel1"
3) (integer) 1
1) "subscribe"
2) "channel2"
3) (integer) 2
1) "subscribe"
2) "channel3"
3) (integer) 3

终端3:

批量订阅 channel*

127.0.0.1:6379> psubscribe channel*

Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "channel*"
3) (integer) 1

终端4:

订阅 channel1

127.0.0.1:6379> subscribe channel1

1) "subscribe"
2) "channel1"
3) (integer) 1

终端5:

订阅 channel2

127.0.0.1:6379> subscribe channel2

Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel2"
3) (integer) 1

终端1:

  • 查看所有活跃频道

127.0.0.1:6379> pubsub channels

1) "channel1"
2) "channel2"
3) "channel3"

  • 向一个新的 channe12 发消息,因为 channel 不存在,会新建

127.0.0.1:6379> publish channel12 hello

(integer) 1 

此时在终端3(批量订阅)有输出

1) "pmessage"
2) "channel*"
3) "channel12"
4) "hello"

其他订阅终端无输出;

  • 向 channel1 发消息

127.0.0.1:6379> publish channel1 hello channel1

(integer) 3

在终端2(订阅了 3 个频道)和终端4(订阅了 channel1)输出一致:

1) "message"
2) "channel1"
3) "hello_channel1"

在终端3(批量订阅)输出:

1) "pmessage"
2) "channel*"
3) "channel1"
4) "hello_channel1"

在终端5(订阅 channel2)无输出

  • 向 channel2 发消息

127.0.0.1:6379> publish channel2 hello channel2

(integer) 3

在终端2(订阅了3个频道)和终端5(订阅了 channel2)输出:

1) "message"
2) "channel2"
3) "hello_channel2"

在终端3(批量订阅)输出:

1) "pmessage"
2) "channel*"
3) "channel2"
4) "hello_channel2"

在终端4(订阅 channel1)无输出;

  • 所有订阅者都退出

在终端2、终端3、终端4、终端5 上面都执行 Ctrl+C 退出订阅,当没有订阅者了,频道自动关闭

此时在终端1 查看活跃频道:

127.0.0.1:6379> pubsub channels

(empty array)

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值