如何限制JMS DefaultMessageListenerContainer重试消息的次数?

时间:2012-05-11 13:40:47

标签: java jms ibm-mq

我使用Spring JMS连接到Websphere MQ服务器。我实现了SessionAwareListener接口来创建自定义侦听器,重用业务逻辑的旧代码。

在测试时,监听器抛出一个StringIndexOutOfBoundsException,我无法捕获。但是,我在日志中看到以下打印了大约32次,然后DMLC停止了。

WARN  - Execution of JMS message listener failed

有没有办法控制DMLC重试邮件的频率,以及如何处理未捕获的异常?

2 个答案:

答案 0 :(得分:5)

您始终可以查看JMSDeliveryCount。如果它超过您认为最大的数字,那么就不要处理该消息并返回。

您也可以configure your Websphere在一些尝试后将错误消息移动到异常目的地。

答案 1 :(得分:5)

在Websphere MQ世界中调用 backout 之后,将消息放回队列。

如何处理它有两种选择:

  1. 在队列管理器中:您可以为给定队列配置回退阈值回退重新排队名称属性。达到回退阈值后,队列管理器会将消息放入由回退重新排队名称指定的队列,而不是重新传递它。有关详细信息,请参阅WebSphere MQ queue properties

  2. 在您的应用程序中:如果您使用JMS API,请在开始处理消息之前通过调用msessage.getIntProperty("JMSXDeliveryCount")来检查JMSXDeliveryCount属性。如果达到某个阈值,则将错误处理为错误。