RabbitMQ 消息队列的工作模式

RabbitMQ 提供了多种工作模式,按照官网的描述,实际上可以分为七种模式

简单模式
  • 作用: 生产者将消息发送到队列,消费者从队列中获取消息。每条消息只能被一个消费者消费。

  • 适用场景: 适用于消息量较小且不需要复杂路由逻辑的场景。

RabbitMQ 提供了多种工作模式,按照官网的描述,实际上可以分为七种模式

工作队列模式
  • 作用: 通过多个消费者分担任务,达到负载均衡的目的。是一种竞争关系的模式,多个消费者之间是竞争关系,即一条消息如果被某个消费者消费了,那么其他的消费者就获取不到了。

  • 适用场景: 适用于需要并行处理大量独立任务的场景,如图像处理、视频转码等

发布/订阅模式
  • 作用: 消息发布到交换机,所有绑定到该交换机的队列都会收到消息。常用的交换机类型是 fanout。

  • 适用场景: 适用于广播消息的场景,如日志处理、事件通知等

路由模式
  • 作用: 消息发布到交换机,并根据路由键将消息发送到相应的队列。以此去匹配交换机和队列的绑定,常用的交换机类型是 direct.

  • 适用场景: 适用于需要对消息进行分类处理的场景,如日志系统中按严重级别分类的日志处理。

主题模式
  • 作用: 消息发布到交换机,并根据路由键模式( 通配符匹配 )将消息发送到相应的队列。常用的交换机类型是topic。

  • 适用场景: 适用于需要根据复杂的路由规则对消息进行分类处理的场景,如日志系统中按模块和严重级别分类的日志处理。

RPC 模式

作用: 实现远程过程调用,客户端发送请求消息到队列,服务器端处理后返回响应消息。 适用场景: 适用于需要实现远程服务调用的场景,如微服务之间的通信。

发布确认模式
  • 作用: 用于确保消息已经成功地发布并被 broker 接收。它提供了一种轻量级的方法来确认消息的持久性和可靠性,适用于需要高可靠性消息传递的场景。

  • 适用场景: 金融交易、订单处理等确保消息被可靠地传递和处理,防止丢失的场景。

相关推荐
python资深爱好者14 分钟前
什么容错性以及Spark Streaming如何保证容错性
大数据·分布式·spark
HeartRaindj1 小时前
【中间件开发】kafka使用场景与设计原理
分布式·中间件·kafka
明达技术3 小时前
探索分布式 IO 模块网络适配器
分布式
爬山算法4 小时前
Zookeeper(58)如何在Zookeeper中实现分布式锁?
分布式·zookeeper·云原生
明达技术6 小时前
分布式 IO 模块:造纸设备的降本增效利器
分布式
星星点点洲10 小时前
【RabbitMQ业务幂等设计】RabbitMQ消息是幂等的吗?
rabbitmq
一位卑微的码农10 小时前
深入解析Spring Cloud Config:构建高可用分布式配置中心
分布式·spring cloud·微服务·架构
Bai_Yin12 小时前
Debezium 与 Apache Kafka 的集成方式
分布式·kafka·apache·debezium
劉煥平CHN12 小时前
RabbitMQ的脑裂(网络分区)问题
网络·分布式·rabbitmq
明达技术12 小时前
分布式 IO 模块:水力发电设备高效控制的关键
分布式