当前位置: 首页 > news >正文

Pub/Sub是什么意思

Pub/Sub(发布/订阅模式)​​ 是一种异步消息通信范式,用于分布式系统中不同组件之间的解耦通信。它的核心思想是将消息的发送方(发布者)​​ 和接收方(订阅者)​​ 分离,通过一个中间层(消息代理)进行消息的路由和分发。


核心概念:

  1. 发布者(Publisher)​

    • 负责产生并发送消息到指定主题(Topic)​,不关心谁接收消息。

    • 例如:传感器发布温度数据、用户行为服务发送日志。

  2. 订阅者(Subscriber)​

    • 主动订阅感兴趣的主题,只接收该主题下的消息。

    • 例如:数据分析服务订阅日志主题,实时告警服务订阅异常数据主题。

  3. 消息代理(Broker)​

    • 中间件组件(如 ​Kafka、RabbitMQ、Google Pub/Sub、Redis Pub/Sub),负责:

      • 接收发布者的消息。

      • 将消息按主题分发给所有订阅者。

      • 管理订阅关系、消息持久化(可选)、负载均衡等。


工作流程:

  1. 订阅者向 Broker ​注册对某个主题的兴趣。

  2. 发布者向 Broker ​发送消息,并指定目标主题。

  3. Broker ​匹配消息的主题,将其复制并推送给所有订阅该主题的订阅者。

  4. 订阅者异步处理收到的消息。


核心特点:

  • 解耦性

    发布者和订阅者无需知道对方存在,添加/移除订阅者不影响发布者。

  • 动态伸缩

    订阅者数量可动态增减,Broker 自动处理负载分配。

  • 一对多广播

    一条消息可同时送达多个订阅者(对比点对点队列的单一消费者)。

  • 异步通信

    发布者发送后无需等待,订阅者按自身节奏消费。


常见应用场景:

  1. 实时通知系统

    :用户注册后,通知邮件服务、推荐系统、数据分析服务并行处理。

  2. 分布式系统解耦

    微服务间通过主题通信,避免直接调用依赖(如订单服务发布order_created,库存服务消费)。

  3. 数据同步

    数据库变更通过CDC(Change Data Capture)发布到主题,多个系统同步数据(如缓存更新、搜索索引)。

  4. 物联网(IoT)设备监控

    百万级设备上报数据至主题,由不同的订阅者处理实时告警、持久化存储、批量分析。

  5. 聊天室/直播互动

    用户消息发布到房间主题,所有订阅该房间的客户端实时接收。


对比其他消息模式:

Pub/Sub

点对点队列(P2P Queue)​

消息消费

一条消息发给所有订阅者

一条消息仅由一个消费者消费

订阅关系

动态订阅/取消订阅主题

队列固定,消费者需绑定队列

场景

广播通知、事件驱动

任务分发、负载均衡(如订单处理)


优缺点:

✅ ​优势

  • 系统扩展性强,新增消费者无需修改发布者。

  • 容错性高:单个订阅者故障不影响整体。

  • 支持高吞吐量场景(如Kafka)。

❌ ​挑战

  • 消息可能重复消费(需幂等设计)。

  • 顺序保证需额外配置(如Kafka分区)。

  • 架构复杂度增加(需部署Broker)。


主流实现工具:

  • 云服务​:Google Cloud Pub/Sub, AWS SNS/SQS, Azure Service Bus

  • 开源​:Apache Kafka, RabbitMQ(需插件), Redis Pub/Sub, NATS

总结:

Pub/Sub 通过主题广播+异步解耦的机制,成为构建高扩展性、松耦合分布式系统的基石。适用于需要事件驱动、实时广播、服务解耦的关键场景,是现代云原生架构的核心组件之一。

http://www.dtcms.com/a/341576.html

相关文章:

  • LWIP的Socket API 与实现关系
  • c#入门笔记(3)
  • 图像数据增强的高效执行
  • Linux下运行Jmeter压测
  • Kafka如何保证「消息不丢失」,「顺序传输」,「不重复消费」,以及为什么会发生重平衡(reblanace)
  • 攻克PostgreSQL专家认证
  • Git Commit 提交信息标准格式
  • Python打卡Day47 注意力热图可视化
  • 字符设备驱动、块设备驱动和网络设备驱动
  • Gitee仓库 日常操作详细步骤
  • Linux服务器性能优化总结
  • 【数据结构】快速排序算法精髓解析
  • shell脚本——搜索某个目录下带指定前缀的文件
  • 50.Seata-AT模式
  • Cyberduck (FTP和SFTP工具) v9.2.3.43590
  • 189.轮转数组
  • 设计模式的一些笔记
  • list集合可以一边遍历一遍修改元素吗?
  • Rust 入门 包 (二十一)
  • 计算机网络基础复习
  • 【数据分享】295个地级市互联网用户、邮电业务数据(2001-2022)
  • win10安装最新docker 4.44.2版图文教程(2025版)
  • 3.Shell脚本修炼手册之---Shell 变量基础知识
  • Android动画小补充
  • 【Obsidian插件】HiNote
  • 爬虫项目实践之淘宝商品详情数据采集​||电商API接口
  • 结构化 OCR 技术:破解各类检测报告信息提取难题
  • 5.Kotlin作用于函数let、run、with、apply、also
  • SpringCloud微服务架构入门指南
  • Day12--滑动窗口与双指针--2762. 不间断子数组,LCP 68. 美观的花束,2743. 计算没有重复字符的子字符串数量