Redis组件先容(六)

打印 上一主题 下一主题

主题 1784|帖子 1784|积分 5352

写在前面

今天学习redis最后的知识。
Redis 的发布与订阅

发布/订阅模式

Redis 提供了两种发布/订阅模式:

  • 基于频道 (Channel) 的发布/订阅
  • 基于模式 (Pattern) 的发布/订阅
干系命令


  • 订阅频道
    1. subscribe channel [channel ...]
    复制代码
    订阅给定的一个或多个频道。
  • 退订频道
    1. unsubscribe channel [channel ...]
    复制代码
    退订给定的频道。若没有指定频道,则默认退订所有频道。
  • 发布消息
    1. publish channel message
    复制代码
    将消息发送给指定频道 channel。返回结果:接收到信息的订阅者数量,无订阅者返回 0。
  • 检察活泼频道
    1. pubsub channels [argument [argument ...]]
    复制代码
    检察订阅与发布系统的状态。返回活泼频道列表(即至少有一个订阅者的频道,订阅模式的客户端除外)。
  • 按模式订阅
    1. psubscribe pattern1 [pattern ...]
    复制代码
    订阅一个或多个符合给定模式的频道。每个模式以 * 作为匹配符;例如 shujia* 匹配所有以 shujia 开头的频道,如 shujia.java、shujia.hadoop。
  • 按模式退订
    1. punsubscribe [pattern [pattern ...]]
    复制代码
    退订所有给定模式的频道。若 pattern 未指定,则退订所有模式;否则只退订指定的模式。
消息队列

在 Redis 中,List 数据范例可以用于排队数据,按照顺序取出,但无法精确获取(双端队列)。这种方式存在两个局限性:

  • 不能支持一对多的消息分发。
  • 如果生产者天生的速度远大于消耗者的消耗速度,易堆积大量未消耗的消息。
脚色


  • 发布者(Publisher):使用 PUBLISH 命令将消息发布到指定的频道。
  • 订阅者(Subscriber):使用 SUBSCRIBE 命令订阅一个或多个频道以接收消息。所有订阅同一频道的订阅者都会收到此消息。
  • 频道(Channel):频道是消息的通道,发布者通过指定频道来发布消息,订阅者通过订阅频道来接收干系消息。
  • 消息(Message):由发布者发送给订阅者的数据。
留意


  • 订阅者使用 SUBSCRIBE 命令订阅频道后,将会一直等待新消息。可以使用 UNSUBSCRIBE 命令取消订阅。
  • Redis 的发布订阅模式不保证消息的可靠传递。如果订阅者在消息发布之前已断开连接,则无法接收到已发布的消息。换句话说,如果先发布消息,再订阅频道,不会收到订阅之前就发布到该频道的消息!
  • Redis 提供了其他干系命令和功能,如按模式订阅 (PSUBSCRIBE)、取消订阅 (UNSUBSCRIBE) 等。可以查阅 Redis 文档以获取更多信息。
请留意:在高吞吐量和大规模发布订阅场景下,Redis 的发布订阅模式可能不是最佳选择,可以考虑使用专门的消息队列系统来替换。
状态表明
  1. localhost:7000> subscribe xiaohu1
  2. Reading messages... (press Ctrl-C to quit)
  3. 1) "subscribe"  # 返回值类型:表示订阅成功!
  4. 2) "xiaohu1"   # 订阅频道的名称
  5. 3) (integer) 1  # 当前客户端已订阅频道的数量
复制代码
示意图



  • 频道订阅:订阅频道时先检查字段内部是否存在;不存在则为当前频道创建一个字典,并创建一个链表存储客户端 ID;否则直接将客户端 ID 插入到链表中。
  • 取消频道订阅:取消时将客户端 ID 从对应的链表中删除;如果删除之后链表为空,则将会把这个频道从字典中删除。
  • 发布:首先根据 channel 定位到字典的键,然后将信息发送给字典值链表中的所有客户端。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

数据人与超自然意识

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表