Redis发布订阅
Redis发布订阅是一种消息通道模式,发送者发送信息,订阅者接收消息
Redis客户端可以定义任意数量的频道
序号 | 命令和描述 |
---|---|
1 | psubscribe pattem 订阅一个或者多个符合给定模式的频道 |
2 | pubsub subcommand 查看订阅与发布系统状态 |
3 | publish channel message 将消息发布到指定的频道 |
4 | punsubscribe 退订所有给定频道 |
5 | subscribe channel 订阅给定的一个或多个频道的消息 |
6 | unsubscribe 指定退订的频道 |
原理:
Redis是使用c实现的
通过subscribe命令订阅某个频道后,Redis-server里维护了一个字典,字典的键就是一个个频道,而字典的值则是一个链表,链表中保存的是所有订阅这个频道的客户端,就是将客户端添加到给定的频道的订阅链表中
通过publish命令向订阅者发送消息,Redis-server会使用给定的频道作为键,在他维护的频道字典中查找记录了订阅这个频道的所有客户端的链表,遍历这个链表,将消息发布到所有订阅者中。
pub/sub 从字面上理解就是publish发布和subscribe订阅,在Redis中,你可以设定对某一个key进行消息发布或者消息订阅,当一个key值上进行了消息发布后,所有订阅他的客户端都会收到相应的消息,这一功能最明显的用法就是用作实时消息系统,比如普通的即使聊天,群聊功能等。