专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

Redis的发布和订阅

Redis的发布和订阅功能分为频道订阅模式订阅两种。每当有其他客户端向被订阅的频道发送消息时,频道的所有订阅者都会收到这条消息。

频道订阅

当一个客户端执行SUBSCRIBE命令订阅某个或某些频道时,这个客户端与被订阅频道之间就建立起了一种订阅关系。

订阅

每当客户端执行SUBSCRIBE命令时,服务器都会将客户端与被订阅的频道在pubsub_channels字典中进行关联。根据频道是否已经其他订阅者,关联操作分两种情况:

1、 如果频道已经有其他订阅者,那么它在pubsub_channels字典中必然有相应的订阅者链表,程序唯一要做的就是将客户端添加到订阅者链表的末尾
2、 如果频道还未有任何订阅者,程序首先在pubsub_channels字典中为频道创建一个键,并将这个键的值设置为空链表,然后再将客户端添加到链表

退订

每当客户端执行UNSUBSCRIBE命令时,服务器将从pubsub_channels中解除订阅关联:

1、 程序根据被退订频道的名字在pubsub_channels字典中找到频道对应的订阅者链表,然后从链表中删除退订客户端信息
2、 如果删除退订客户端之后,频道的订阅者链表变成空链表,程序将从pubsub_channels字典中删除频道对应的键

模式订阅

服务器将所有模式的订阅关系都保存在服务器状态的pubsub_patterns属性里面。

订阅

每个客户端执行PSUBSCRIBE命令订阅某个或某些模式的时候,服务器会对每个被订阅的模式执行以下两个操作:

1、 新建一个pubsubPattern结构,将结构的pattern属性设置为被订阅的模式,client属性设置为订阅模式的客户端
2、 将pubsubPattern结构添加到pubsub_patterns链表的表尾

退订

当一个客户端退订某个或某些模式的时候,服务器将在链表pubsub_patterns中查找并删除那些pattern属性为被订阅模式,并且client属性为执行退订命令的客户端的pubsubPattern结构

发送消息

当一个Redis客户端执行PUBLISH <channel> <message>命令经消息message发送给频道channel的时候,服务器需要执行以下两个动作:

1、 在pubsub_channels字典中找到频道channel的订阅者名单,然后将消息发送给名单上的所有客户端
2、 遍历整个pubsub_patterns链表,查找那些与channel频道相匹配的模式,并将消息发送给订阅了这些模式的客户端

文章永久链接:https://tech.souyunku.com/19812

未经允许不得转载:搜云库技术团队 » Redis的发布和订阅

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们