JBoss 7.0.1 xa-datasource异常。 javax.transaction.xa.XAException

时间:2013-12-26 07:24:16

标签: java mysql oracle jboss7.x ejb-3.1

我使用两个独立的数据源。使用EJB3.0我使用的是non-Xa-datasources。我的错误是这样的:could not open connectionstate-aware object。这是因为在一个stateless bean中我调用了第二个stateless bean的方法,它连接了不同的数据库。 然后我更改datasources structure并将其更改为xa-datasources,如下所示:

<datasources>
            <xa-datasource jndi-name="java:/ooo" pool-name="ooo" enabled="true" use-java-       context="true">
                <xa-datasource-property name="URL">
                    jdbc:oracle:thin:@xxx.xxx.xxx.xxx:xxxx:orcl
                </xa-datasource-property>
                <driver>oracle</driver>
                <security>
                 </security>
            </xa-datasource>
            <xa-datasource jndi-name="java:jboss/mysqlds" pool-name="mysqlds" enabled="true" use-java-context="true">
                <xa-datasource-property name="URL">
                    jdbc:mysql://127.0.0.1/test
                </xa-datasource-property>
                <driver>mysql</driver>
                <security>
                </security>
            </xa-datasource>
            <drivers>
                <driver name="oracle" module="com.oracle.ojdbc">
                    <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class>
                </driver>
                <driver name="mysql" module="com.mysql.jdbc">
                    <xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>
                </driver>
            </drivers>
        </datasources>

因此我在启动jboss中出现了一些错误,我将mysql module.xml这个(dependency> javax.transaction.api.):{/ p>

<dependencies>
  <module name="javax.api"/>    
  <module name="javax.transaction.api"/>  
</dependencies>

一切正常,但每2分钟就有warning

 11:00:16,213 WARN  [com.arjuna.ats.jta] (Periodic Recovery) ARJUNA016027: Local XARecoveryModule.xaRecovery got XA exception XAException.XAER_RMERR: javax.transaction.xa.XAException
at oracle.jdbc.xa.OracleXAResource.recover(OracleXAResource.java:709)
at org.jboss.jca.adapters.jdbc.xa.XAManagedConnection.recover(XAManagedConnection.java:358)
at org.jboss.jca.core.tx.jbossts.XAResourceWrapperImpl.recover(XAResourceWrapperImpl.java:162)
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.xaRecovery(XARecoveryModule.java:503) [jbossjts-4.16.2.Final.jar:]
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.resourceInitiatedRecoveryForRecoveryHelpers(XARecoveryModule.java:471) [jbossjts-4.16.2.Final.jar:]
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.bottomUpRecovery(XARecoveryModule.java:385) [jbossjts-4.16.2.Final.jar:]
at com.arjuna.ats.internal.jta.recovery.arjunacore.XARecoveryModule.periodicWorkSecondPass(XARecoveryModule.java:166) [jbossjts-4.16.2.Final.jar:]
at com.arjuna.ats.internal.arjuna.recovery.PeriodicRecovery.doWorkInternal(PeriodicRecovery.java:789) [jbossjts-4.16.2.Final.jar:]
at com.arjuna.ats.internal.arjuna.recovery.PeriodicRecovery.run(PeriodicRecovery.java:371) [jbossjts-4.16.2.Final.jar:]

1 个答案:

答案 0 :(得分:1)

我解决了这个问题。 问题是user。这个用户我使用的是另一个已经运行的应用程序。 我创建了新的user,一切正常