辛星浅析Redis中的pub/sub功能

      pub/sub功能也就是publish/subscribe功能,也就是发布订阅功能。基于事件的系统中,pub/sub是目前广泛使用的通信模型,它采用事件作为基本的通信机制,提供大规模系统所要求的松散耦合的交互模式:订阅者比如客户端以事件订阅的方式表达出它有兴趣接收的一个事件或一类事件,发布者比如服务器可以将订阅者兴趣的事件随时通知相关订阅者。



    pub/sub功能可以有三个非耦合:

    (1)时间非耦合,也就是发布者和订阅者不必同时在线,它们不必同时参与交互。

    (2)空间非耦合,也就是发布者和订阅者不必相互知道对方所在的位置。发布者通过事件服务发布时间,订阅者通过事件服务间接获得事件。发布者和订阅者不需要拥有直接到对方的引用,也不必知道有多少个订阅者或者是发布者参与交互。

    (3)同步非耦合,发布/订阅是异步模式。发布者可以不断的产生事件,而订阅者(通过一个回调)则可以异步地得到产生事件的通知。

   

    pub/sub功能按照订阅方式分为基于主题(topic-based)、基于内容(content-based)、基于类型(type-based)的方式。它是可适用于可扩展性高、松散耦合系统的分布式交互模型。在抽象层中,它的时间非耦合、空间非耦合和空间非耦合性可允许参与者不依赖于另一个而独立操作,具有一定的可扩展性。但是在实现的时候,可扩展性依然受到其他原因的牵制。

    pub/sub通常适用的范围:

    (1)灵活的订阅要求复杂的过滤和路由算法

    (2)高可用性开销(事件侦听、日志重传)

    (3)消息认可带来的网络流量消耗

    (4)庞大的订阅者数据带来的系统开销

    基于事件的pub/sub中间件的开发与利用在一定程度上可以提高系统的效率。


     Redis中的实现流程:

    (1)订阅者订阅两个topic,范例:

              subscribe   first    second

    (2)发布者发布信息,范例:  

              publish   first   hello      

              publish  second    world

    (3)订阅者取消一个topic,返利:

             unsubscribe   first












  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值