我使用两个单独的数据源。使用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.)放在了其中:

<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:]

最佳答案

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

08-06 21:41