Redis的频道发布与消息订阅

ゝ一纸荒年。 2021-12-15 02:21 342阅读 0赞

Redis的频道发布与消息订阅

官网介绍

进程间的一种通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

订阅/发布消息图

下图展示了频道channel1,以及订阅这个频道的三个客户端-client2、client5、client1

1477786-20190528000433192-1155333420.jpg

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

1477786-20190528000455202-870867470.jpg

Redis 发布订阅命令

  1. PSUBSCRIBE pattern [pattern ...]

订阅一个或者多个符合模式匹配的频道

【假设客户端同时订阅了某种模式和符合该模式的某个频道,那么发送给这个频道的消息将被客户端接收到两次,只不过这两条消息的类型不同,一个是message类型,一个是pmessage类型,但其内容相同。 】

  1. PUBSUB subcommand [argument [argument ...]]

返回由活跃频道组成的列表,即可以查询订阅与发布系统的状态

  1. PUBLISH channel message

发送消息到指定的频道

【其返回值为接收到该消息的订阅者的数量】

  1. SUBSCRIBE channel [channel ...]

订阅一个或多个频道

【其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道】

  1. PUNSUBSCRIBE [pattern [pattern ...]]

退订所有符合模式匹配的频道

  1. UNSUBSCRIBE [channel [channel ...]]

退订一个或多个频道

【Redis采用UNSUBSCRIBE和PUNSUBSCRIBE命令取消订阅,其返回值与订阅类似。
由于Redis的订阅操作是阻塞式的,因此一旦客户端订阅了某个频道或模式,就将会一直处于订阅状态直到退出。

在SUBSCRIBE,PSUBSCRIBE,UNSUBSCRIBE和PUNSUBSCRIBE命令中,

其返回值都包含了该客户端当前订阅的频道和模式的数量,当这个数量变为0时,该客户端会自动退出订阅状态。】

简单练习

客户端先订阅后,消息发布后才能接收到消息

  1. 可以一次性订阅多个,SUBSCRIBE c1 c2 c3
  2. 消息发布,PUBLISH c2 hell0-redis
  3. 订阅多个,通配符*,PSUBSCRIBE new*
  4. 收取消息,PUBLISH new1 redis2019

转载于:https://www.cnblogs.com/-wenli/p/10934549.html

发表评论

表情:
评论列表 (有 0 条评论,342人围观)

还没有评论,来说两句吧...

相关阅读