Redis的频道发布与消息订阅

Redis的频道发布与消息订阅

 

官网介绍

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

 

订阅/发布消息图

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

 

 

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

 

 

Redis 发布订阅命令

PSUBSCRIBE pattern [pattern ...]

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

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

 

PUBSUB subcommand [argument [argument ...]]

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

 

PUBLISH channel message 

发送消息到指定的频道

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

 

SUBSCRIBE channel [channel ...] 

订阅一个或多个频道

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

 

PUNSUBSCRIBE [pattern [pattern ...]] 

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

 

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

 

posted @ 2019-05-28 00:15  -零  阅读(2603)  评论(0编辑  收藏  举报