Java分布式事务概念与实现示例
发表于:2007-07-01来源:作者:点击数:
标签:
在java中有如下三种事务, 简单的JDBC级的事务 JTA - 在EJB环境下,用户得到事务并进行控制 CMP - 完全由容器控制事务,用户通过Bean配置文件来定义事务行为 二三种都支持分布式事务,但只支持 Java 环境下的分布式事务。 下面讨论如何在Java程序里实现分布
在java中有如下三种事务,
- 简单的JDBC级的事务
- JTA - 在EJB环境下,用户得到事务并进行控制
- CMP - 完全由容器控制事务,用户通过Bean配置文件来定义事务行为
二三种都支持分布式事务,但只支持Java环境下的分布式事务。
下面讨论如何在Java程序里实现分布式事务,即在同一个事务里访问多个数据源。实际上就是如何使用JTA.
这里假设使用Oracle数据库,使用WebLogic部署应用,所要做的是如下几步:
1. 配置
1.1 确认数据库支持分布式事务 - oracle是支持分布式事务的,JDBC驱动也支持分布式事务
1.2 在WebLogic里配置DataSource
1.2.1. 配置连接池,注意这里应该选择驱动是Thin XA而不是Thin
1.2.2. 配置数据源,使用前面配好的XA的连接池
2. 程序实现
2.1. 实现自己的Xid
import javax.transaction.xa.*;
public class MyXid implements Xid
{
protected int formatId;
protected byte gtrid[];
protected byte bqual[];
public MyXid()
{
}
public MyXid(int formatId, byte gtrid[], byte bqual[])
{
this.formatId = formatId;
this.gtrid = gtrid;
this.bqual = bqual;
}
public int getFormatId()
{
return formatId;
}
public byte[] getBranchQualifier()
{
return bqual;
}
public byte[] getGlobalTransactionId()
{
return gtrid;
}
}
原文转自:http://www.ltesting.net