6

我正在使用 activemq 在不同进程之间传递请求。在某些情况下,我在队列中有多个重复的消息(它们是请求)。我想只有一个。有没有办法发送一条消息,它将替换具有相似属性的旧消息?如果没有,有没有办法检查队列并检查具有特定属性的消息(在这种情况下,如果存在旧消息,我将不会发送新消息)。

澄清(基于戴夫的回答):我实际上是在尝试确保队列上没有任何重复的消息,以减少消费者收到消息时发生的处理量。因此,我想替换一条消息,甚至不把它放在队列中。

谢谢。

4

2 回答 2

3

这听起来像是幂等消费者的理想用例,它从队列或主题中删除重复项。

以下示例显示了如何使用Apache Camel执行此操作,这是实现任何企业集成模式的最简单方法,特别是如果您使用的是随 Camel开箱即用集成的ActiveMQ

from("activemq:queueA").
  idempotentConsumer(memoryMessageIdRepository(200)).
  header("myHeader").
  to("activemq:queueB");

唯一的技巧是确保有一种简单的方法来计算每条消息的唯一 ID 表达式 - 例如从文档中提取 XPath 或使用如上例中的一些唯一消息头

于 2008-10-27T08:11:35.170 回答
1

您可以浏览队列并使用选择器来识别消息。但是,除非您有少量消息,否则这不会很好地扩展。相反,您的消息应该只是指向数据库记录(或记录集)的指针。这样您就可以更新记录,任何收到消息的人都将访问最新版本的记录。

于 2008-10-24T19:09:20.423 回答