JTA和JTS
Java事务API(JTA:Java Transaction API)和它的同胞Java事务服务(JTS:Java Transaction Service),为J2EE平台提供了分布式事务服务(distributed transaction)。
一个资源管理器(resource manager)是任意类型的持久化数据存储。
事务管理器(transaction manager)承担着所有事务参与单元者的相互通讯的责任。
JTA与JDBC
JTA事务比JDBC事务更强大。一个JTA事务可以有多个参与者,而一个JDBC事务则被限定在一个单一的数据库连接。下列任一个Java平台的组件都可以参与到一个JTA事务中:JDBC连接、JDO PersistenceManager 对象、JMS 队列、JMS 主题、企业JavaBeans(EJB)、一个用J2EE Connector Architecture 规范编译的资源分配器。
划分
要用JTA来划分一个事务,应用程序调用javax.transaction.UserTransaction接口中的方法。
示例4显示了一个典型的JNDI搜索的UseTransaction对象。
import javax.transaction.*;
import javax.naming.*;
// ...
InitialContext ctx = new InitialContext();
Object txObj = ctx.lookup(";java:comp/UserTransaction";);
UserTransaction utx = (UserTransaction) txObj;
应用程序有了UserTransaction对象的引用之后,就可以象示例5那样来起动事务。
utx.begin();
// ...
DataSource ds = obtainXADataSource();
Connection conn = ds.getConnection();
pstmt = conn.prepareStatement(";UPDATE MOⅥES ...";);
pstmt.setString(1, ";Spinal Tap";);
pstmt.executeUpdate();
// ...
utx.commit();
// ...
|
当应用程序调用commit()时,事务管理器使用两段提交协议来结束事务。
JTA事务控制的方法:
.javax.transaction.UserTransaction接口提供
使用
应用程序调用begin()来起动事务,即可调用commit()也可以调用rollback()来结束事务。
开发人员经常使用JDBC来作为DAO类中的底层数据操作。
如果计划使用JTA来划分事务,你将需要一个实现了javax.sql.XADataSource,javax.sql.XAConnection和javax.sql.XAResource接口JDBC的驱动。
实现了这些接口的驱动将有能力参与到JTA事务中。
一个XADataSource对象是一个XAConnection对象的工厂。XAConnections是参与到JTA事务中的连接。你需要使用应用程序服务器管理工具来建立XADataSource对象。
特殊指令
对于特殊的指令请参考应用程序服务器文档和JDBC驱动文档。
J2EE应用程序使用JNDI来查找数据源。
一旦应用程序有了一个数据源对象的引用,这会调用javax.sql.DataSource.getConnection()来获得数据库的连接。
连接
XA 连接区别于非XA连接。要记住的是XA连接是一个JTA事务中的参与者。这就意味着XA连接不支持JDBC的自动提交特性。也就是说应用程序不必在XA连 接上调用java.sql.Connection.commit()或java.sql.Connection.rollback()。相反,应用程序应 该使用UserTransaction.begin()、UserTransaction.commit()和 UserTransaction.rollback().
注意
让我们来关注下面的话:
“用 JTA 界定事务,那么就需要有一个实现 javax.sql.XADataSource 、 javax.sql.XAConnection 和 javax.sql.XAResource 接口的 JDBC 驱动程序。一个实现了这些接口的驱动程序将可以参与 JTA 事务。一个 XADataSource 对象就是一个 XAConnection 对象的工厂。XAConnection s 是参与 JTA 事务的 JDBC 连接。”
要使用JTA事务,必须使用XADataSource来产生数据库连接,产生的连接为一个XA连接。
XA连接(javax.sql.XAConnection)和非XA(java.sql.Connection)连接的区别在于:XA可以参与JTA的事务,而且不支持自动提交。
Note:
Oracle,Sybase,DB2,SQL Server等大型数据库才支持XA,支持分布事务。
My SQL 连本地都支持不好,更别说分布事务了。
MySql 在5.0的版本后增加了对xa的支持
参考:
http://baike.baidu.com/link?url=XyJuG3vKGXVEXAwGWZygdistGMIHKZe4sUvA4X9WzC8hbR0b7nKcjZ9YciAv0cmS#1_1
http://www.ibm.com/developerworks/cn/java/j-lo-jta/
相关推荐
JTA提供了一种统一的方式来处理不同类型的事务管理,包括本地事务和全局事务,使得开发者可以编写无感知于具体事务系统的代码,增强了代码的可移植性和可维护性。 `geronimo-jta_1.1_spec-1.1.1.jar`包含了JTA 1.1...
总之,理解Geronimo-JTA_1.1_spec-1.1.1.jar的源码有助于我们更好地掌握JTA规范,并在实际开发中有效利用其提供的事务管理能力。同时,结合Hibernate框架,我们可以构建出健壮、高效的企业级应用,处理复杂的事务...
`atomikos-transactions-jta.jar` 文件是Atomikos Transactions JTA库的二进制发行版,包含必要的类和资源,用于在Java项目中引入Atomikos事务管理服务。这个`.jar`文件通常会作为项目依赖添加到构建工具(如Maven或...
JTA允许应用程序在不同的数据源之间进行跨平台的事务管理,支持两阶段提交(2PC)等高级事务特性。Geronimo JTA 1.1包含了以下关键组件: 1. UserTransaction接口:应用程序通过该接口启动、回滚和查询当前事务状态...
本项目"spring-jta-mybatis"着重讲解了如何在Spring框架中结合JTA(Java Transaction API)和MyBatis实现分布式事务管理。 首先,分布式数据源是在多数据库环境下的一个重要概念。当业务需求扩大,单一数据库无法...
在JavaWeb和JavaEE应用程序中,JTA主要解决了数据库事务管理的问题,尤其是在涉及多个数据源时。传统的本地事务处理仅限于单个资源管理器,而JTA支持全局事务,即能够跨越多个资源管理器进行事务协调,确保所有操作...
在“Lab4-JTA-code_jta_choiceh76_”这个实验中,我们将会深入探讨JTA如何实现这一功能,并通过具体的代码示例进行学习。 JTA的核心目标是提供一种统一的接口,使得应用开发者可以编写事务处理代码,而无需关心底层...
对应的`.class`文件(如`myJDBCUpdateServlet`、`myJTAServlet`、`myJDBCReadServlet`)是这些Servlet的编译后版本,它们可能包含了具体的JDBC数据库操作和JTA事务管理的代码。`www.pudn.com.txt`可能是一个文档,...
春天jta-narayana JTA,JPA,Hibernate和Narayana的Spring项目 ... 在tx:annotation-driven的applicationContext.xml中指示事务管理器。 另外包含:Log4J(根据: ://spring.io/blog/2009/12/04/logging-dep
综上所述,"第二部分spring+hibernate+jta 分布式事务Demo"涵盖了Spring、Hibernate和JTA在分布式事务管理中的核心概念和实践,是学习和理解这一领域的重要参考资料。通过学习和实践这个Demo,开发者可以提升自己在...
Spring框架在企业级Java应用中广泛用于实现事务管理,而JTA(Java Transaction API)是Java平台上的标准事务处理API,适用于分布式环境。本篇文章将深入探讨如何在Spring中配置JTA事务管理,以实现跨数据库和资源的...
### 跨数据库的事务管理配置JTA:XML的详细配置 在现代软件开发过程中,特别是在企业级应用中,经常需要处理跨多个数据源的操作。为了确保数据的一致性和完整性,通常会采用分布式事务来实现这一目标。Java ...
在Spring Boot应用中,整合JTA(Java Transaction API)实现多数据源事务管理是一个常见的需求,特别是在分布式系统中,为了确保数据的一致性和完整性。本文将深入探讨如何配置和使用Spring Boot与JTA来管理多个...
标题中的“spring-jta-atomikos”是一个关于在Spring框架中使用JTA(Java Transaction API)和Atomikos的项目。JTA是Java平台中用于管理分布式事务的标准API,而Atomikos是一个开源的事务管理器,它支持JTA,并且在...
XA协议是数据库层面的一套分布式事务管理的规范,JTA是XA协议在Java中的实现,多个数据库或是消息厂商实现JTA接口,开发人员只需要调用SpringJTA接口即可实现JTA事务管理功能。 JTA事务比JDBC事务更强大。一个JTA事务...
JTA(Java Transaction API) 为 J2EE 平台提供了分布式事务服务。 要用 JTA 进行事务界定,应用程序要调用 javax.transaction.UserTransaction 接口中的方法。
- **JTA与JPA/EJB集成**:在Java EE环境中,JTA与JPA(Java Persistence API)和EJB(Enterprise JavaBeans)结合,实现统一的事务管理。 5. **最佳实践** - **事务边界设定**:明确事务开始和结束的位置,避免长...
描述中提到了"jbarcode-0.2.8"和"jbarcodebean-1.2.0",这是关于Java条形码生成库JBarcode的不同版本,但主要关注点是JTA,因为"jta-1.0.1B"和"jta-1.1"再次被提及。这表明讨论的是用于处理分布式事务的Java技术。 ...
在Spring中,Java Transaction API (JTA) 和 JOTM(Java Open Transaction Manager)是实现分布式事务管理的关键组件。 **Spring 框架** Spring 是一个开源的Java平台,它提供了一个全面的编程和配置模型,用于现代...
JTA(XA)事务是Java Transaction API(JTA)的事务机制,它可以管理分布式事务,涉及多个资源管理器和事务管理器。JTA事务可以将多个资源管理器组合成一个事务,以确保分布式事务的一致性和可靠性。 使用JTA事务...