码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Redis发布订阅与原理


    文章目录

    • Redis发布与订阅
      • 1、订阅与退订的原理
        • I. 频道的订阅与退订
        • II. 模式的订阅与退订
      • 2、发布的原理
        • I. 发布给频道订阅者
        • II. 发布给模式订阅者
      • 3、其它命令

    Redis发布与订阅

    Redis的发布与订阅功能通过PUBLISH、SUBSCRIBE/UNSUBSCRIBE、PSUBSCRIBE/PUNSUBSCRIBE等命令组成。

    • 通过SUBSCRIBE,客户端可以订阅一个或多个频道,成为这些频道的订阅者,并可以通过UBSUBSCRIBE退订。
    • 通过PSUBSCRIBE,客户端可以订阅一个或多个模式,成为这些频道的订阅者,并可以通过PUBSUBSCRIBE退订。
    • 每当有其他客户端通过PUBLISH向这些频道发送消息时,频道的所有订阅者都将收到这条消息。

    注:模式就是使用了通配符的频道名,比如news.*。

    通配符:

    • ?:一个占位符
    • *:0至多个占位符
    • ?*:一个及以上个占位符

    1、订阅与退订的原理

    I. 频道的订阅与退订

    1. Redis服务器维护了一个名为pubsub_channels的字典,字典的键是被订阅的频道,值是订阅了这些频道的客户端链表。

    2. 当一个客户端订阅(SUBSCRIBE)频道时,服务器首先到字典中查找是否有这个频道。

      • 如果有,则将该客户端放至链表的末尾。

      • 如果没有,则先创建该频道的键,然后将客户端插入链表。

    3. 当一个客户端退订(UNSUBSCRIBE)频道时,服务器到字典中找到频道的键并删除该客户端的信息。如果删除后链表为空,则将键一并删除。

    II. 模式的订阅与退订

    1. Redis服务器维护了一个名为pubsub_pattern的链表,每个链表节点存储了客户端及其订阅的模式。
    2. 当客户端订阅(PSUBSCRIBE)模式时,服务器创建一个存储客户端及其订阅模式的链表节点,并将其添加至链表的末尾。
    3. 当客户端退订(PUNSUBSCRIBE)模式时,服务器在链表中寻找对应的节点并将其删除。

    2、发布的原理

    I. 发布给频道订阅者

    Redis服务器根据频道名到字典中查找对应的订阅客户端链表,然后将信息发送给所有的订阅者。

    II. 发布给模式订阅者

    Redis服务器遍历pubsub_pattern链表,并将消息发送给订阅了对应模式的客户端。

    3、其它命令

    • PUBSUB CHANNELS [pattern]:查看当前服务器中被订阅的频道,如果提供了pattern字段,则查看当前服务器中符合pattern模式的频道。
    • PUBSUB NUMSUB channel [channel1 …]:返回当前服务器中对应频道的订阅者数量。
    • PUBSUB NUMPAT:返回当前服务器中订阅了模式的订阅者数量。
  • 相关阅读:
    自然语言处理中的文本聚类:揭示模式和见解
    Java PrintWriter.write()方法具有什么功能呢?
    JSON.stringify()与JSON.parse()没有你想的那样简单
    【校招VIP】前端专业课考点之其它协议和端口
    艺人百度百科怎么创建
    GCN 链结预测 负采样 想要请教链结预测当中的负采样问题
    机器学习:基于Python实现人工神经网络训练过程
    NetCore.CAP mqttws31.js RabbitMq 订阅发布消息
    文件搜索工具(Python实现)
    【数字IC设计】VCS门级网表仿真
  • 原文地址:https://blog.csdn.net/Wyf_Fj/article/details/126555707
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号