多数据库项目出现的问题(jta+xa)

问题:用seam建立ear工程,工程使用了两个数据库,当访问数据库时不要出现冲突的时候工程是没有问题的,如果同时访问两个数据库的时候就会出现数据库无法连接的现象:
javax.persistence.PersistenceException: org.hibernate.exception.GenericJDBCException: Cannot open connection
然后所有的访问数据库都出现这个错误;
解决方法:首先采用了两个数据库,我们必须采用jta事务来处理(这里不讲jta事务的配置),主要讲解决的方法,因为seam自动生成数据源(goldeninfo-ds.xml)采用了本地数据源,不适用多库数据源,所以这里我们要创建分布式事务要配置XA的数据源(goldeninfo-xa-ds.xml),如Jboss给的示例 JBOSS/docs/examples/jca/oracle-xa-ds.xml。这里我们采用了mysql数据库,下面是XA数据源的参考配置:
<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE datasources PUBLIC "-//JBoss//DTD JBOSS JCA Config 1.5//EN"
"http://www.jboss.org/j2ee/dtd/jboss-ds_1_5.dtd">
<datasources>
<xa-datasource>
<jndi-name>goldeninfoDatasource</jndi-name>
<xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>
<xa-datasource-property name="Url">jdbc:mysql://localhost:3306/goldeninfo</xa-datasource-property>
<xa-datasource-property name="User">root</xa-datasource-property>
<xa-datasource-property name="Password">root</xa-datasource-property>

<track-connection-by-tx>true</track-connection-by-tx>
<new-connection-sql>set autocommit=1</new-connection-sql>
<no-tx-separate-pools>true</no-tx-separate-pools>

<metadata>
<type-mapping>mySQL</type-mapping>
</metadata>
</xa-datasource>

<xa-datasource>
<jndi-name>goldeninfojbpm</jndi-name>
<xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>
<xa-datasource-property name="Url">jdbc:mysql://localhost:3306/goldenjbpm</xa-datasource-property>
<xa-datasource-property name="User">root</xa-datasource-property>
<xa-datasource-property name="Password">root</xa-datasource-property>

<track-connection-by-tx>true</track-connection-by-tx>
<new-connection-sql>set autocommit=1</new-connection-sql>
<no-tx-separate-pools>true</no-tx-separate-pools>

<metadata>
<type-mapping>mySQL</type-mapping>
</metadata>
</xa-datasource>

</datasources>

注:蓝色部分比jboss中多出来的,一定要加,不加照样不行的;记得把原来的goldeninfo-ds.xml文件去掉,因为两个数据源不能同时存在。这样还不行,你启动jboss的时候没有问题,但你登陆(既第一次访问数据库的时候)就会出现下面的错误:
2007-05-16 14:17:28,078 ERROR [org.jboss.resource.adapter.jdbc.xa.XAManagedConnectionFactory] End transaction failed for XAResource
com.mysql.jdbc.jdbc2.optional.MysqlXAException: XAER_INVAL: Invalid arguments (or unsupported command)
at com.mysql.jdbc.jdbc2.optional.MysqlXAConnection.mapXAExceptionFromSQLException(MysqlXAConnection.java:564)

我们继续,找到在jboss下的deploy/ear-deployer.xml文件修改其中的值:

<attribute name="Isolated">true</attribute>
<attribute name="CallByValue">true</attribute>

到这里就算修改完毕,启动jboss即可。
可以参考:http://seamframework.org/Community/MultipleDatasourcesAndXADatasource
http://stenlylee.iteye.com/category/53846?show_full=true
http://community.jboss.org/wiki/ConfigDataSources
http://zhangsiwei-1001.iteye.com/blog/430598
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值