我有一个 MDB 订阅了一个主题,该主题发送的消息最终被持久化到数据库中。
我知道 MDB 是池化的,因此容器能够并行处理多个传入消息。在我的例子中,这些消息被消费(然后被持久化)的顺序很重要。我不希望 MDB 实例池在消息在 JMS 主题中发布时以不同的顺序使用并持久保存消息。
这可能是一个问题吗?如果是这样,有没有办法告诉容器在消费消息时遵循严格的传入顺序?
我有一个 MDB 订阅了一个主题,该主题发送的消息最终被持久化到数据库中。
我知道 MDB 是池化的,因此容器能够并行处理多个传入消息。在我的例子中,这些消息被消费(然后被持久化)的顺序很重要。我不希望 MDB 实例池在消息在 JMS 主题中发布时以不同的顺序使用并持久保存消息。
这可能是一个问题吗?如果是这样,有没有办法告诉容器在消费消息时遵循严格的传入顺序?
您应该能够将 MDB 池的大小限制为 1,从而确保以正确的顺序处理消息。
当然,如果你仍然想要一些并行性,那么你有几个选择,但这真的取决于数据。
如果某些消息有共同点,并且处理顺序只在具有共同值的那组消息中很重要,那么您可能需要有多个主题,或者使用队列和线程池。
另一方面,如果与消息到达相关的逻辑的某些部分可以并行发生,而其他位则不能,那么您需要将逻辑拆分为并行正常和并行不正常部分,并相应地处理这些位。
从那里复制:
为确保收据顺序与客户端发送消息的顺序相匹配,您必须执行以下操作:
将 MDB 的 max-beans-in-free-pool 设置为 1。这确保了 MDB 是消息的唯一使用者。
如果您的 MDB 部署在集群上,请将它们部署到集群中的单个节点,[...]。