欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Redis 发布订阅

程序员文章站 2022-03-10 12:13:06
...

Redis 发布订阅

1、介绍

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。
Redis 客户端可以订阅任意数量的频道。

eg:以微博和公众号,任何粉丝只要关注(订阅)了某一个人的微博或者公众号,该微博或者公众号只有有状态更新,都会将消息推送(发布)到粉丝

下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:

Redis 发布订阅

当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:

Redis 发布订阅

 

2、Redis 发布订阅命令

1	psubscribe pattern [pattern ...]
订阅一个或多个符合给定模式的频道。
2	pubsub subcommand [argument [argument ...]]
查看订阅与发布系统状态。
3	publish channel message
将信息发送到指定的频道。
4	punsubscribe [pattern [pattern ...]]
退订所有给定模式的频道。
5	subscribe channel [channel ...]
订阅给定的一个或多个频道的信息。
6	unsubscribe [channel [channel ...]]
指退订给定的频道。

eg:

订阅"chat"频道(客户端1)

127.0.0.1:6379> psubscribe chat
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "chat"
3) (integer) 1

在"chat"频道上发布一个消息(客户端2)

127.0.0.1:6379> publish chat "hello chat"
(integer) 1

发布后在客户端1上可以看到

127.0.0.1:6379> psubscribe chat
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "chat"
3) (integer) 1
1) "pmessage"
2) "chat"
3) "chat"
4) "hello chat"

 

相关标签: Redis NoSQL