避免在JMS/ActiveMQ上重复的消息

And*_*ore 20 java activemq-classic jms duplicates mom

有一种方法可以抑制ActiveMQ服务器上定义的队列上的重复消息吗?

我尝试手动定义JMSMessageID,(message.setJMSMessageID("uniqueid")),但服务器忽略此修改并传递带有内置生成的JMSMessageID的消息.

根据规范,我没有找到关于如何重复删除邮件的参考.

在HornetQ中,为了解决这个问题,我们需要在消息定义上声明HQ特定属性org.hornetq.core.message.impl.HDR_DUPLICATE_DETECTION_ID.

即:

Message jmsMessage = session.createMessage();
String myUniqueID = "This is my unique id"; // Could use a UUID for this
message.setStringProperty(HDR_DUPLICATE_DETECTION_ID.toString(), myUniqueID);
Run Code Online (Sandbox Code Playgroud)

有人知道ActiveMQ是否有类似的解决方案?

Tim*_*ish 7

您应该查看Apache Camel,它提供了一个可与任何JMS提供程序一起使用的Idempotent使用者组件,请参阅:http://camel.apache.org/idempotent-consumer.html

将它与ActiveMQ组件结合使用可以非常简单地使用JMS,请参阅:http: //camel.apache.org/activemq.html

  • 我怀疑这个方法是否能解决我的问题。我只需要在队列中保留一个具有相同 JMSMessageID 的消息实例。我需要它作为一个集合工作。我希望能够在从队列中删除最新的 idem 元素后放置具有相同 JMSMessageID 的其他消息。我需要实施它并进行测试。但是,根据EAI书中描述的幂等,我认为这个概念与我的需要不符。但是,建议的解决方案很好。我将进一步研究它并在这里评论我的结果。谢谢 (2认同)

Bij*_*men 5

我怀疑ActiveMQ是否本身就支持它,但是实现幂等消费者应该很容易。一种方法是在生产者端为每个消息添加唯一的标识符,现在在消费者端使用商店(数据库,缓存等),可以检查消息是否在之前和之后收到。继续根据该检查进行处理。

我在同一行上看到了先前的stackoverflow问题-Apache ActiveMQ 5.3-如何配置队列以拒绝重复消息?,这也可能会有所帮助。