我正在使用带有JCA资源适配器和MDB的JBOSS EAP 6.4的IBM MQ v7.5。 MQ服务器在HP NonStop Integrity服务器v5.3.1.12
中运行该应用程序正常运行。但我在日志中看到以下异常
[com.arjuna.ats.jta] (Periodic Recovery) ARJUNA016027: Local XARecoveryModule.xaRecovery got XA exception XAException.XAER_RMFAIL: javax.transaction.xa.XAException
at com.ibm.mq.connector.RecoveryXAResource.checkExceptions(RecoveryXAResource.java:147)
at com.ibm.mq.connector.RecoveryXAResource.recover(RecoveryXAResource.java:514)
at org.jboss.jca.core.tx.jbossts.XAResourceWrapperImpl.recover(XAResourceWrapperImpl.java:185)
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.xaRecoveryFirstPass(XARecoveryModule.java:541) [jbossjts-jacorb-4.17.29.Final-redhat-1.jar:4.17.29.Final-redhat-1]
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.periodicWorkFirstPass(XARecoveryModule.java:181) [jbossjts-jacorb-4.17.29.Final-redhat-1.jar:4.17.29.Final-redhat-1]
at com.arjuna.ats.internal.arjuna.recovery.PeriodicRecovery.doWorkInternal(PeriodicRecovery.java:747) [jbossjts-jacorb-4.17.29.Final-redhat-1.jar:4.17.29.Final-redhat-1]
at com.arjuna.ats.internal.arjuna.recovery.PeriodicRecovery.run(PeriodicRecovery.java:375) [jbossjts-jacorb-4.17.29.Final-redhat-1.jar:4.17.29.Final-redhat-1] Caused by: com.ibm.msg.client.wmq.v6.jms.internal.ConfigEnvironment$1: MQJMS1068: failed to obtain XAResource.
at com.ibm.msg.client.wmq.v6.jms.internal.ConfigEnvironment.newException(ConfigEnvironment.java:379)
at com.ibm.msg.client.wmq.v6.jms.internal.MQXAConnection.createXASession(MQXAConnection.java:155)
at com.ibm.msg.client.jms.internal.JmsXAConnectionImpl.createXASession(JmsXAConnectionImpl.java:125)
at com.ibm.mq.jms.MQXAConnection.createXASession(MQXAConnection.java:88)
at com.ibm.mq.connector.RecoveryXAResource.recover(RecoveryXAResource.java:490)
... 5 more Caused by: javax.transaction.xa.XAException: The method 'xa_open' has failed with errorCode '-3'.
at com.ibm.mq.jmqi.JmqiXAResource.<init>(JmqiXAResource.java:274)
at com.ibm.mq.jmqi.JmqiXAResource.getInstance(JmqiXAResource.java:122)
at com.ibm.mq.jmqi.JmqiEnvironment.newJmqiXAResource(JmqiEnvironment.java:1598)
at com.ibm.msg.client.wmq.v6.base.internal.MQXAQueueManager.getXAResource(MQXAQueueManager.java:175)
at com.ibm.msg.client.wmq.v6.jms.internal.MQXAConnection.createXASession(MQXAConnection.java:134)
... 8 more
任何人都可以帮助我理解为什么会这样吗?
此外,即使我停止了我的服务器,也没有杀死与MQ服务器的连接。它仍然是一个孤儿。它是否与此异常有关?
我在standalone.xml中的资源适配器配置中使用NoTransaction
答案 0 :(得分:0)
我错过了这个问题的重点(由于缺乏IBM MQ知识)。也就是说,我的MQ服务器在HP NonStop Integrity服务器上运行。这些服务器不支持XA连接。因此这个错误。
现在,问题是如何阻止它。
我已使用以下属性停止了JBOSS中的定期恢复:
name =“RecoveryEnvironmentBean.periodicRecoveryPeriod”value =“0” name =“RecoveryEnvironmentBean.recoveryBackoffPeriod”value =“0”
答案 1 :(得分:-2)
这是一个已知问题。 IBM已发布修订包以解决此问题。请参阅:
http://www-01.ibm.com/support/docview.wss?uid=swg1IC97579
IBM MQ V7.5.0.4及更高版本具有此修复程序。
而且,是的,您的孤立连接是此问题的结果。