【发布时间】:2020-03-31 11:39:38
【问题描述】:
RabbitMQ 是否在以下情况下轮询分发消息?
RabbitMQ 配置:
- 交换类型 - 主题
- 路由键 - 通知。#
生产者正在将消息推送到上面的交换中,并带有以下内容 不同的主题-
notify.log.#、notify.status.#、notify.priceChange.#
有 4 个消费者在不同的服务器上运行。
-
3 个消费者在负载均衡器下执行相同的处理并在同一应用程序的不同实例上运行。(他们希望消费生产者推送的每条消息)
他们正在收听带有路由键 "notify.#" 的“notification_queue”。
-
剩余的第 4 个消费者正在做一些与前 3 个消费者不同的处理,并在不同的服务器(不同的应用程序)上运行。
它正在侦听带有路由键 "notify.log.#" 的“log_queue”。
RabbitMQ 是否会以循环方式在前 3 个消费者中分发消息(在第 1 点)?
请帮忙。
【问题讨论】:
-
是的,它是循环的,请注意,如果一个消费者挂起,其他消费者仍然会收到消息。所以这不是“公平调度”。但平均而言,随着时间的推移,他们应该收到相同数量的消息。
标签: rabbitmq