Kafka - 消息队列的两种模式

文章目录


消息队列的两种模式

消息队列确实可以根据消息传递的模式分为

  • 点对点模式
  • 发布/订阅模式

这两种模式有不同的特点和应用场景:

点对点模式(Point-to-Point,P2P)

  1. 点对点模式(Point-to-Point,P2P):

    • 在点对点模式中,有一个生产者(Producer)将消息发送到一个特定的队列(Queue)。
    • 只有一个消费者(Consumer)可以接收和处理队列中的消息。
    • 消息在队列中存储,一旦被消费者接收,就会从队列中删除。

这种模式适用于一对一的通信,其中生产者和消费者之间有直接的关联,通常用于任务分发和处理。


发布/订阅模式(Publish/Subscribe,Pub/Sub)

  1. 发布/订阅模式(Publish/Subscribe,Pub/Sub):
    • 在发布/订阅模式中,生产者将消息发布到一个主题(Topic)而不是队列。
    • 多个消费者可以订阅一个或多个主题,以接收相关的消息。
    • 消息广播给所有订阅了相应主题的消费者,每个消费者都会收到一份消息的拷贝。

这种模式适用于一对多的通信,其中消息的发送者不需要关心谁会接收消息,通常用于事件处理、日志记录和实时通知等场景。


小结

消息队列主要分为两种模式:点对点模式(一个生产者对口一个消费者)和发布/订阅模式(一对多)。

这两种模式有各自的优势和适用性,选择哪种模式取决于应用程序的需求。

  • 点对点模式适用于有明确定位的消息接收者的情况
  • 发布/订阅模式适用于需要将消息广播给多个订阅者的情况。

在实际的消息队列系统中,可以根据需求选择合适的模式来实现不同类型的消息传递。

相关推荐
Jackeyzhe5 小时前
从零学习Kafka:配置参数
kafka
编程彩机8 小时前
互联网大厂Java面试:从分布式架构到大数据场景解析
java·大数据·微服务·spark·kafka·分布式事务·分布式架构
難釋懷10 小时前
分布式锁-redission锁重试和WatchDog机制
分布式
kobe_t13 小时前
分布式定时任务系列14:XXL-job的注册模型
分布式
Knight_AL14 小时前
线程池满了怎么办?用 RabbitMQ 做任务补偿不丢失
分布式·rabbitmq·ruby
難釋懷16 小时前
分布式锁-redission锁的MutiLock原理
分布式
小北方城市网17 小时前
RabbitMQ 生产级实战:可靠性投递、高并发优化与问题排查
开发语言·分布式·python·缓存·性能优化·rabbitmq·ruby
乾元17 小时前
拒绝服务的进化:AI 调度下的分布式协同攻击策略
人工智能·分布式
编程彩机17 小时前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
听麟18 小时前
HarmonyOS 6.0+ PC端多设备文件拖拽协同开发实战:手眼同行增强与分布式软总线深度应用
分布式·华为·harmonyos