JTA及两阶段提交协议

来源:互联网 发布:设计服装软件下载 编辑:程序博客网 时间:2024/05/09 12:32

JTA

Java Transaction API(Java事务API) (JTA)Java Transaction API(Application Programming Interface)


什么是JTA Transaction?它有怎样的特点呢?JTA Transaction是指由J2EE Transaction manager去管理的事务。其最大的特点是调用UserTransaction接口的begin,commit和rollback方法来完成事务范围的界定,事务的提交和回滚。JTA Transaction可以实现同一事务对应不同的数据库,但是它仍然无法实现事务的嵌套。



分布式事务的规范由OMG的OTS所描述。  
JTA是只是一组java接口用于描述,J2ee框架中事务管理器与应用程序,资源管理器,以及应用服务器之间的事务通讯。  
它主要包括高层接口即面向应用程序的接口;XAResource接口即面向资源的接口;以及事务管理器的接口。值得注意的是JTA只提供了接口,没有具体的实现。  
JTS是服务OTS的JTA的实现。简单的说JTS实现了JTA接口,并且符合OTS的规范。  
   
资源管理器只要其提供给事务管理器的接口符合XA接口规范,就可以被事务管理器处理。  
   
所以,JTA可以处理任何提供符合XA接口的资源。包括:数据库,JMS,商业对象等等 


“Java 事务 API”(JTA)启用两阶段提交功能。

 

 

 

两阶段提交协议

 

实现分布式事务的关键就是两阶段提交协议。在此协议中,一个或多个资源管理器的活动均由一个称为事务协调器的单独软件组件来控制。此协议中的五个步骤如下:

 

 

  1. 应用程序调用事务协调器中的提交方法。
  2. 事务协调器将联络事务中涉及的每个资源管理器,并通知它们准备提交事务(这是第一阶段的开始)。
  3. 为 了以肯定的方式响应准备阶段,资源管理器必须将自己置于以下状态:确保能在被要求提交事务时提交事务,或在被要求回滚事务时回滚事务。大多数资源管理器会 将包含其计划更改的日记文件(或等效文件)写入持久存储区中。如果资源管理器无法准备事务,它会以一个否定响应来回应事务协调器。
  4. 事务协调器收集来自资源管理器的所有响应。
  5. 在 第二阶段,事务协调器将事务的结果通知给每个资源管理器。如果任一资源管理器做出否定响应,则事务协调器会将一个回滚命令发送给事务中涉及的所有资源管理 器。如果资源管理器都做出肯定响应,则事务协调器会指示所有的资源管理器提交事务。一旦通知资源管理器提交,此后的事务就不能失败了。通过以肯定的方式响 应第一阶段,每个资源管理器均已确保,如果以后通知它提交事务,则事务不会失败。
事务提交

事务回滚
原创粉丝点击