【发布时间】:2015-11-29 16:11:15
【问题描述】:
我正在评估使用 RabbitMQ 作为消息队列/消息总线,并且一直在查看 RabbitMQ 页面上的示例 tutorials。
我正在寻找教程未涵盖的特定场景,我不确定是否以及如何通过 RabbitMQ 进行操作。
设置:
假设我有一项服务,我们称其为“采购订单”,而我必须使用其他服务,称为“物流”和“会计”。
发送订单时,我想通过 RabbitMQ 将其作为消息发送。
有 2 个“账户”和 3 个“物流”服务
确保“帐户”和“物流”只处理一次消息的正确方法是什么?如果我理解正确,使用 pub/sub 将导致消息被处理两次(帐户)或三次(物流)。
使用工作队列和 prefetch=1 可以确保只有一个获得它,但我有 2 个服务并且希望每种类型的服务都获得一个。
有没有一种方法可以将两者结合起来并为每个服务设置一个工作队列,而无需将 2 个单独的事件/消息发送到两个不同的交换器?
【问题讨论】: