【问题标题】:Spring JMS MQJE001: Completion Code '2', Reason '2042'Spring JMS MQJE001:完成代码“2”,原因“2042”
【发布时间】:2011-06-27 05:31:03
【问题描述】:

我的设置是 Spring 3 JMS、MVC + Websphere MQ + Websphere 7

<!-- this is the Message Driven POJO (MDP) -->
<bean id="messageListener" class="com.SomeListener" />

<!-- and this is the message listener container -->
<bean id="jmsContainer"
    class="org.springframework.jms.listener.DefaultMessageListenerContainer">
    <property name="connectionFactory" ref="xxxCF" />
    <property name="destination" ref="someQueue" />
    <property name="messageListener" ref="messageListener" />
</bean>

当我启动服务器时,侦听器似乎正确启动,因为它接收到我放入队列中的消息。

但是,一旦我运行任何与 JMS 无关的简单控制器/动作,它就会一遍又一遍地给我下面的消息...

DefaultMessag W org.springframework.jms.listener.DefaultMessageListenerContainer handleListenerSetupFailure Setup of JMS message listener invoker failed for destination 'queue:///ABCDEF.EFF.OUT?persistence=-1' - trying to recover. Cause: MQJMS2008: failed to open MQ queue ''.; nested exception is com.ibm.mq.MQException: MQJE001: Completion Code '2', Reason '2042'.
DefaultMessag I org.springframework.jms.listener.DefaultMessageListenerContainer refreshConnectionUntilSuccessful Successfully refreshed JMS Connection

ConnectionEve W   J2CA0206W: A connection error occurred.  To help determine the problem, enable the Diagnose Connection Usage option on the Connection Factory or Data Source.

ConnectionEve A   J2CA0056I: The Connection Manager received a fatal connection error from the Resource Adapter for resource JMS$XXXQCF$JMSManagedConnection@2. The exception is: javax.jms.JMSException: MQJMS2008: failed to open MQ queue ''.

ConnectionEve W   J2CA0206W: A connection error occurred.  To help determine the problem, enable the Diagnose Connection Usage option on the Connection Factory or Data Source.

ConnectionEve A   J2CA0056I: The Connection Manager received a fatal connection error from the Resource Adapter for resource jms/XXXQCF. The exception is: javax.jms.JMSException: MQJMS2008: failed to open MQ queue ''.

原来的监听器似乎仍在正常运行......但我认为控制器以某种方式触发了另一个连接? 有谁知道我应该检查什么或可能导致此问题的原因?

谢谢

【问题讨论】:

  • 当我启动 websphere 时,监听器和一切工作正常。一旦我遇到类似@RequestMapping("/doSomething") public String doSomethingHandler() throws Exception {........它会开始重复的 2042 错误
  • 我认为主要问题是为什么点击弹簧控制器会使侦听器尝试创建另一个连接??

标签: spring jms websphere ibm-mq websphere-7


【解决方案1】:

2042 表示“正在使用的对象”。由于没有消息生产者独占使用队列的概念,因此您的一个消费者正在锁定队列。

此行为由queue definition's DEFSOPT attribute 控制。这是在队列管理器本身,而不是在托管对象定义或您的工厂选项中。从命令行以 mqm(或者如果 QMgr 在 Windows、iSeries、z/OS 等上,则为等效平台)登录时,您需要启动 runmqsc 并发出以下命令来验证并修复问题。在我的示例中,QMgr 是 PLUTO,示例队列是 SYSTEM.DEFAULT.LOCAL.QUEUE。

/home/mqm: runmqsc PLUTO
5724-H72 (C) Copyright IBM Corp. 1994, 2009.  ALL RIGHTS RESERVED.
Starting MQSC for queue manager PLUTO.

dis q(system.default.local.queue) defsopt
     1 : dis q(system.default.local.queue) defsopt
AMQ8409: Display Queue details.
   QUEUE(SYSTEM.DEFAULT.LOCAL.QUEUE)       TYPE(QLOCAL)
   DEFSOPT(EXCL)
alter ql(system.default.local.queue) defsopt(shared)
     2 : alter ql(system.default.local.queue) defsopt(shared)
AMQ8008: WebSphere MQ queue changed.
dis q(system.default.local.queue) defsopt
     3 : dis q(system.default.local.queue) defsopt
AMQ8409: Display Queue details.
   QUEUE(SYSTEM.DEFAULT.LOCAL.QUEUE)       TYPE(QLOCAL)
   DEFSOPT(SHARED)

如果您显示队列并发现它已经为 DEFSOPT(SHARED) 设置,那么必须通过 API 指定队列的独占使用。这通常意味着 C 或基本 Java 程序,因为这些非 JMS API 可以访问低级 WMQ 功能。诊断这些可能有点棘手,我通常使用跟踪或SupportPac MA0W 退出来显示使用的 API 调用和选项。如果是这种情况,我想更多地了解原始帖子中提到的“简单控制器/动作”的含义。

最后,如果您正在访问的队列是远程队列,那么它将解析为传输队列。通道将始终将传输队列设置为 GET(INHIBITED) 并在其上获取排他锁。这与 WMQ 功能一致,因为应用程序只能从本地队列获取消息。

【讨论】:

  • 我知道我的 DefaultMessageListenerContainer 侦听器在我启动 Websphere 服务器后立即锁定它。我感到困惑的是,为什么当我点击一个除了返回视图之外什么都不做的控制器时,Spring 会尝试创建另一个新的侦听器并连接到队列......
  • 我们经常看到来自同一个 JMS 应用程序的多个队列连接。通常其中之一是浏览队列并通过 MessageID 将读取请求分派给各个线程。我们也经常看到一个线程打开队列进行查询,以获取回退队列的详细信息,然后立即再次打开以进行输入。如果您好奇,请按照上述说明安装 SupportPac MA0W。这就像一个跟踪,但如果需要,您可以选择只跟踪一个队列。非常酷的东西。
猜你喜欢
  • 2014-03-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-06-29
  • 1970-01-01
  • 2021-05-06
  • 2021-06-08
相关资源
最近更新 更多