【九】、Redis发布与订阅

导读:本篇文章讲解 【九】、Redis发布与订阅,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

九、Redis发布与订阅

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:
订阅
每当有新消息通过PUBLISH命令发送给频道1时,这个消息就会被发送给订阅它的三个客户端
发送消息
命令

命令 描述
PSUBSCRIBE pattern [pattern…] 订阅一个或多个符合给定模式的频道。
PUNSUBSCRIBE pattern [pattern…] 退订一个或多个符合给定模式的频道。
PUBSUB subcommand [argument[argument]] 查看订阅与发布系统状态。
PUBLISH channel message 向指定频道发布消息
SUBSCRIBE channel [channel…] 订阅给定的一个或多个频道。
SUBSCRIBE channel [channel…] 退订一个或多个频道
------------订阅端----------------------
127.0.0.1:6379> SUBSCRIBE sakura # 订阅sakura频道
Reading messages... (press Ctrl-C to quit) # 等待接收消息
1) "subscribe" # 订阅成功的消息
2) "sakura"
3) (integer) 1
1) "message" # 接收到来自sakura频道的消息 "hello world"
2) "sakura"
3) "hello world"
1) "message" # 接收到来自sakura频道的消息 "hello i am sakura"
2) "sakura"
3) "hello i am sakura"

--------------消息发布端-------------------
127.0.0.1:6379> PUBLISH sakura "hello world" # 发布消息到sakura频道
(integer) 1
127.0.0.1:6379> PUBLISH sakura "hello i am sakura" # 发布消息
(integer) 1

-----------------查看活跃的频道------------
127.0.0.1:6379> PUBSUB channels
1) "sakura"

原理:

每个Redis服务器进程都维持着一个表示服务器状态的 redis.h/redisServer
结构,结构的pubsub_channels属性是一个字典,这个字典就是用于保存订阅频道的信息,其中字典的键为正在被订阅的频道,二字典的值则是一个链表,链表中保存了所有订阅这个频道的客户端。
在这里插入图片描述
客户端订阅,就被连接到对应频道的链表的尾部,退订就是将该客户端节点从链表中移除

缺点:

  1. 如果一个客户端订阅了频道,但自己读取消息的速度却不够快的话,那么不断积压的消息会使redis输出缓冲区的体积变得越来越大,这可能使得redis本身得速度变慢,甚至直接崩溃
  2. 这和数据传输可靠性有关,如果在线订阅放断线,那么他将会丢失在断线期内发布者发布的消息

应用场景:

  1. 消息订阅:公众号订阅、微博关注等等(其实更多是使用消息队列来实现的)
  2. 多人在线聊天室
    稍微复杂的场景我们就会使用消息中间件MQ处理

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/81915.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!