分布式缓存Redis之发布/订阅(pub/sub)

SUBSCRIBE、UNSUBSCRIBE和PUBLISH 三个命令实现了发布与订阅信息泛型(Publish/Subscribe messaging paradigm),在这个实现中, 发送者(发送信息的客户端)不是将信息直接发送给特定的接收者(接收信息的客户端), 而是将信息发送给频道(channel), 然后由频道将信息转发给所有对这个频道感兴趣的订阅者。 而是将信息发送给频道(channel), 然后由频道将信息转发给所有对这个频道感兴趣的订阅者。也就是说发送者无须知道任何关于订阅者的信息, 而订阅者也无须知道是那个客户端给它发送信息, 它只要关注自己感兴趣的频道即可

对发布者和订阅者进行解构(decoupling),可以极大地提高系统的扩展性(scalability),并得到一个更动态的网络拓扑(network topology)。

redis可以订阅任意数量的频道。

分布式缓存Redis之发布/订阅(pub/sub)_第1张图片

频道channel1,和订阅频道的三个客户端-client2。。。。之间的关系。

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

分布式缓存Redis之发布/订阅(pub/sub)_第2张图片

二:原理

RedisServer有两个重要的结构:

1:channels:实际是一个key-value的map结构,key为订阅的频道,value为client的list

2:patterns:存放模式+client地址的列表

流程:从pubsub_channel中找出跟publish中channel相符的client-list,然后再去pubsub_patterns中找出每一个相符的pattern和client。向这些客户端发送publish的消息。


三:信息格式

 频道转发的每条信息都是一条带有三个元素的多条批量回复(multi-bulk reply)。信息的第一个元素标识了信息的类型:

  • subscribe : 表示当前客户端成功地订阅了第二个元素所指示的频道,而信息的第三个元素则记录了目前客户端已订阅频道的总数。
  • unsubscribe : 表示当前客户端成功地退订了第二个元素所指示的频道,信息的第三个元素记录了客户端目前仍在订阅的频道数量。当客户端订阅的频道数量降为 0 时, 客户端不再订阅任何频道, 它可以像往常一样, 执行任何 Redis 命令。
  • message : 表示这条信息是由某个客户端执行 PUBLISH 命令所发送的真正的信息。 信息的第二个元素是信息来源的频道, 而第三个元素则是信息的内容。

Redis 的发布与订阅实现也支持模式匹配(pattern matching): 客户端可以订阅一个带 * 号的模式, 如果某个/某些频道的名字和这个模式匹配, 那么当有信息发送给这个/这些频道的时候, 客户端也会收到这个/这些频道的信息。

redis>   PSUBSCRIBE news.*

客户端将接收来自news.art.figurative、news.music.jazz等频道的信息。

四:实例

以下实例演示了发布订阅是如何工作的,在我们实例中我们订阅的频道为redischat在客户端1执行

分布式缓存Redis之发布/订阅(pub/sub)_第3张图片

你可能感兴趣的:(redis)