当前位置: 首页 > 面试题库 >

如何使用Java和Spring 3.0同时处理来自JMS主题(而非队列)的多个消息?

山鸿彩
2023-03-14
问题内容

我希望多个消息侦听器可以同时处理该主题的后续消息。另外,我希望每个消息侦听器都可以事务性地操作,以便给定消息侦听器中的处理失败将导致该侦听器的消息保留在主题上。

春天的DefaultMessageListenerContainer似乎仅支持JMS队列的并发。

我需要实例化多个DefaultMessageListenerContainers吗?

如果时间沿垂直轴向下流动:

ListenerA reads msg 1        ListenerB reads msg 2        ListenerC reads msg 3
ListenerA reads msg 4        ListenerB reads msg 5        ListenerC reads msg 6
ListenerA reads msg 7        ListenerB reads msg 8        ListenerC reads msg 9
ListenerA reads msg 10       ListenerB reads msg 11       ListenerC reads msg 12
...

我最终要做的是创建多个对象DefaultMessageListenerContainersconcurrency=1然后在消息侦听器中放入逻辑,以便只有一个线程可以处理给定的消息ID。


问题答案:

你不想要多个DefaultMessageListenerContainer实例,不,但是你需要DefaultMessageListenerContainer使用concurrentConsumers属性将并发配置为:

指定要创建的并发使用者数。默认值为1。

为此设置指定较高的值将提高运行时调度的并发使用者的标准级别:这实际上是在任何给定时间调度的最小并发使用者数。这是静态设置;对于动态缩放,请考虑改为指定“ maxConcurrentConsumers”设置。

建议增加并发使用者的数量,以扩展从队列传入的消息的用量。但是,请注意,一旦注册了多个使用者,任何订购保证都将丢失。通常,对于少量队列,请坚持使用1个使用者。

但是,在底部有一个大警告:

不要增加主题的并发使用者数量。这将导致同时消耗同一消息,这几乎是不希望的。

这很有趣,并且在你考虑时是有道理的。如果你有多个DefaultMessageListenerContainer实例,则会发生相同的情况。

我想也许你需要重新考虑你的设计,尽管我不确定我会建议什么。并发使用pub / sub消息似乎是一件很合理的事情,但是如何避免同一条消息同时传递给所有使用者呢?



 类似资料:
  • 我可以在solace JMS队列中搜索任何特定的消息,然后在其他消息之前处理吗?我们有这样的功能w. r. t慰藉队列。

  • 当谈到JMS队列/主题时,我很困惑。我想要的是消息应该发给每个订阅者,并且我希望订阅者在处于活动状态时从非活动时间接收消息。但是,我无法控制订阅者是否具有持久订阅。有没有办法设置持久队列,并将其设置为每个订阅者都会收到相同的消息?以及如何使用Spring配置进行设置 非常感谢。

  • 我们最近遇到了由RabbitMQ支持的应用程序的意外行为。RabbitMQ版本为3.6.12,我们使用的是.NET客户端5.0.1 应用程序订阅了两个队列,一个用于命令,另一个用于事件--我们还使用手动确认。我们的应用程序配置为有7个消费者。每个通道都有自己的通道(IModel),每个通道都有自己的EventingBasicConsumer,当EventingBasicConsumer.Recei

  • 我正在开发一个使用的软件。我有一个用户订阅了多个主题,我想知道是否有一个订单接收来自这些主题的消息。我在我的电脑上尝试了一些组合,但我需要确定这一点。例 null [编辑]我想指定这两个主题各有一个分区,并且只有一个生产者和一个消费者。我需要首先阅读来自第一个主题的所有消息,然后阅读来自另一个主题的消息

  • 我已经创建了一个队列。生产者持续发布到JMS队列。但是,使用者需要一些时间来处理消息,一段时间后队列就会满。 如何在生产者端(即Java应用程序)和JMS代理上处理这种情况?