码农知识堂 - 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:返回当前服务器中订阅了模式的订阅者数量。
  • 相关阅读:
    贪心算法-会议室问题
    TypeScript基础常用知识点总结
    从命令行管理文件(二)
    hive 中正则表表达式使用
    go高并发之路——go语言如何解决并发问题
    Django的网站项目开发好了,该用何种方案在Centos上部署【答:Gunicorn(uWSGI)+Nginx】
    如何正确的中断线程?你的姿势是否正确
    抖音商流量怎么提升|成都聚华祥
    代码随想录算法训练营第53天|1143. 最长公共子序列,1035. 不相交的线,53. 最大子数组和
    java多线程面试总结,字节跳动java面试题
  • 原文地址: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号