RabbitMQ是怎么做消息分发的?

rabbitMQ一个有6种工作模式(消息分发方式)分别是简单模式,工作队列模式,发布订阅模式,路由模式,主题模式以及RPC模式。

1.简单模式是最基本的工作模式,也是最简单的消息传递模式。在简单模式中,一个生产者将消息发送到一个队列中,一个消费者从队列中获取并处理消息。这种模式适用于单个生产者和单个消费者的简单场景,消息的处理是同步的。

2.工作队列模式用于实现一个任务在多个消费者之间的并发处理。在工作队列模式中,一个生产者将消息发送到一个队列中,多个消费者从队列中获取并处理消息。每个消息只能被一个消费者处理。这种模式使用于多个消费者并发处理消息的情况,提供了系统的处理能力和吞吐量

3.发布订阅模式用于实现一条消息被多个消费者同时接收和处理。在发布/订阅模式中,一个生产者将消息发送到交换器中,交换器将消息广播到所有绑定的队列,每个队列对应一个消费者。这种模式适用于消息需要被多个消费者同时接收和处理的广播场景,如日志订阅和事件通知等。

4.路由模式用于实现根据消息的路由键(Routing key)将消息路由到不同的队列中。在路由模式中,一个生产者将消息发送到交换器中,并指定消息的路由键,交换机根据路由键将消息路由到于之匹配的队列中。这种模式使用于根据不同的条件将消息发送到不同的队列中,以实现消息的筛选和分发。

5.主题模式是一种更灵活的消息路由模式,它使用通配符匹配路由键,将消息路由到多个队列中。在主题模式中,一个生产者将消息发送到交换器中,并指定主题 作为路由键,交换器根据通配符匹配将消息路由到匹配的队列中。这种模式适用于消息的复制路由需求,可以实现高度灵活的消息筛选和分发。

  1. RPC模式是一种用于实现分布式系统中远程调用的工作模式。指的是通过RabbitMQ来实现一种RPC的能力

这几种模式,根据不同的场景可以用不同的模式,每种模式的发送方及接收方的代码都不太一样,有的简单,有的复杂,具体实现可以参考:

https://www.rabbitmq.com/getstarted.html

相关推荐
herobrineAC7894 小时前
Hyperopt 强大的分布式参数优化框架全解析
分布式·其他
明达智控技术5 小时前
MR30系列分布式I/O在造型机产线的应用
分布式·物联网·自动化
Moniane5 小时前
A2A+MCP构建智能体协作生态:下一代分布式人工智能架构解析
人工智能·分布式·架构
爱敲键盘的猴子5 小时前
MQ高级 -- RabbitMQ
rabbitmq
ttghgfhhjxkl5 小时前
Windows 系统下 RabbitMQ 延迟插件的安装步骤与常见问题修复
windows·rabbitmq·ruby
即兴随缘6 小时前
【RabbitMQ】RPC模式(请求/回复)
rabbitmq·.net
꒰ঌ 安卓开发໒꒱6 小时前
RabbitMQ面试全解析:从核心概念到高可用架构
面试·架构·rabbitmq
观望过往16 小时前
Kafka 全方位详细介绍:从架构原理到实践优化
分布式·架构·kafka
LB211216 小时前
Redis黑马点评 分布式锁
数据库·redis·分布式
回家路上绕了弯20 小时前
接口响应时间优化指南:从秒级到毫秒级的全链路方案
分布式·后端