Redis如何实现发布订阅功能
文章目录
- Redis如何实现发布订阅功能
- 前言
- 一、Redis发布订阅功能
- 1. 发送消息
- 2. 订阅某个频道
- 3. 发布订阅的实现
- 4. 总结
前言
Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者,订阅者和Channel。
发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个频道的订阅者就能接收到这条消息。Redis的这种发布订阅机制与基于主题的发布订阅类似,Channel相当于主题。
一、Redis发布订阅功能
1. 发送消息
Redis采用PUBLISH命令发送消息,其返回值为接收到该消息的订阅者的数量。
2. 订阅某个频道
Redis采用SUBSCRIBE命令订阅某个频道,其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道。
3. 发布订阅的实现
订阅端:
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> SUBSCRIBE dingdada #订阅名字为 dingdada 的频道
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "dingdada"
3) (integer) 1
#等待推送的信息
1) "message" #消息
2) "dingdada" #来自哪个频道的消息
3) "hello world\xef\xbc\x81" # 消息的具体内容
1) "message"
2) "dingdada"
3) "my name is dyj\x81"
发送端:
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> PUBLISH dingdada "hello world!" #发送消息到dingdada 频道
(integer) 1
127.0.0.1:6379> PUBLISH dingdada "my name is dyj" #发送消息到dingdada 频道
(integer) 1
PSUBSCRIBE 命令:订阅指定频道!
PUBLISH + 频道 +消息 #将信息 message 发送到指定的频道 channel
PUNSUBSCRIBE命令:退订!
#指示客户端退订指定模式,若果没有提供模式则退出所有模式。
SUBSCRIBE:订阅,同上一致。
UNSUBSCRIBE:退订,同上一致
4. 总结
Pub/Sub 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个key值进行消息发布及消息订阅,当一个key值上进行了消息发布后,所有订阅它的客户端都会收到相应的消息。这一功能最明显的用法就是用作实时消息系统,比如普通的即时聊天,群聊等功能。
回到顶部