发布订阅使用场景
类似于rabbit MQ这种消息中心,Redis也可以实现消息队列的功能,适用场景类似公众号的订阅和接收,当一个订阅者订阅了一个公众号,当发布者发布文章或消息的时候,可以将消息放在消息中心,而订阅者可以直接从消息中心获取到特定的消息。
发布订阅的实现
发布订阅主要的方法如下:
首先客户端订阅一个频道
127.0.0.1:6379> subscribe purpleStars
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "purpleStars"
3) (integer) 1
然后发布者将消息发送到指定频道
127.0.0.1:6379> publish purpleStars hello
(integer) 1
127.0.0.1:6379> publish purpleStars hi
(integer) 1
客户端将受到指定频道发送过来的信息
127.0.0.1:6379> subscribe purpleStars
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "purpleStars"
3) (integer) 1
1) "message"
2) "purpleStars"
3) "hello"
1) "message"
2) "purpleStars"
3) "hi"
Redis发布订阅原理及使用场景
Redis发布订阅实际上是在redis-service上维护了一个字典,每个字典的key相当于一个channel,而每个字典的value则是一串链表,连接了所有订阅者,消息发送者只需要向字典中特定位置插入消息,消息接受者就会收到发布的消息。
使用场景:
- 实时消息系统
- 实时聊天系统
- 消息(公众号、B站账号等)订阅