RabbitMQ是怎么做消息分发的?

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

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

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

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

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

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

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

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

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

相关推荐
笃行客从不躺平20 分钟前
Token 复习
java·分布式·spring cloud
u0104058362 小时前
分布式淘客系统的配置中心设计:Nacos在多环境配置管理的应用
分布式
迎仔3 小时前
01-Hadoop 核心三剑客通俗指南:从“单机搬砖”到“包工队”
大数据·hadoop·分布式
ALex_zry3 小时前
分布式缓存与微服务架构的集成
分布式·缓存·架构
ALex_zry4 小时前
分布式缓存安全最佳实践
分布式·安全·缓存
陌上丨7 小时前
分布式锁的特性是什么?如何实现分布式锁?
分布式
yangSnowy7 小时前
MySQL 分布式锁实现方案
数据库·分布式·mysql
ALex_zry8 小时前
分布式缓存性能优化策略
分布式·缓存·性能优化
七夜zippoe8 小时前
分布式配置中心终极对决 Spring Cloud Config与Apollo架构深度解析
分布式·架构·springcloud·apollo·配置中心
迎仔8 小时前
09-消息队列Kafka介绍:大数据世界的“物流枢纽”
大数据·分布式·kafka