`
yangzb
  • 浏览: 3506750 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

什么是xa 1次事务2次事务回滚

    博客分类:
  • Java
阅读更多

数据库不支持XA事务怎么办?
Deepak Vohra写了一篇文章,介绍了如何在WebLogic Server上配置和使用PostgreSQL。这篇文章无疑是使用PosgreSql的很好的入门,但是它没有说明该数据库面对企业级开发时的局限性。 不要误解我的意思,我个人认为PosgreSql是一个很不错的数据库,对于特定的项目来说,即使比起领先的商业数据库RDBMS,它也是极好的免费替代 方案。我自己就曾在几个项目中使用PostgreSql,它确实是一流的数据库,我推荐您在为下一个项目选择数据库时可以考虑一下它。它具有很多优点:易 于安装和管理,可靠性好,设置了很不错的功能,具有标准兼容性,甚至还有顺序支持(这使它在PK生成策略方面可以很方便地与Oracle兼容),等等。

但我还是认为开发人员应该了解他们所使用的工具的局限性,甚至应该比了解工具的优点了解得更详细一些。作为一个优秀的数据库,PosgreSql缺乏对分 布式(XA)事务的支持,至少在最新的版本8中还不支持。我不是很关注PosgreSql的开发,所以我不知道XA支持是否被列入以后版本的计划中了(如 果有人知道详情,请在此回复,我将非常高兴能看到这种帖子)。实际上,我认为目前还没有任何免费的开源数据库具备XA支持,是这样的吧?希望能有人告诉我 我错了。

关键是要分析项目的需求,看看对于这个项目来说XA支持是否重要。就我而言,我发现对于我所参与的大多数企业项目来说,XA支持非常重要。几乎每次应用程 序必须同时处理多个资源管理器(考虑一下MDB更新数据库的情况)时,使用XA事务都可以获得更好的服务质量(QoS)。有人可能会说,大多数应用程序不 需要XA(或者没有XA也行),这在某种程度上是正确的,但是往往会增加开发的工作量(在上面所提到的例子中是对副本的监测),或者会降低QoS。有时必 须使用XA来交付用例所要求的功能。

不管怎么说,回到本文的主题上来——如果使用的数据库不支持XA事务,但是由于某些原因又需要使用它,那该怎么办?除了手动模拟或避免XA事务,还有一种 事务最优化技术:Last resource commit(最近资源提交),在当前的大多数事务管理器实现中都包含这一技术。它的思想是,可以在具有若干个支持两阶段提交的资源的事务中使用不支持 XA的单阶段资源(例如,只能提交或回滚,不支持准备阶段)。事务管理器随后威胁非XA资源(方式随管理器不同而有所不同),此时它先执行两阶段(XA) 资源的准备阶段,然后如果它决定提交资源,就把控制权交给非XA资源。如果该资源提交了,那么管理器记录提交的决定,并尝试提交其他的资源(提交协议的第 二阶段)。如果由于某种原因对非XA资源的提交失败,事务管理器将回滚到先前准备的XA资源。可以想象得出,会有一些失败场景,其中可能失去原子性,但是 总体上来说这种场景在实践中出现得非常少。

WebLogic Server从版本9开始支持Last Resource Commit最优化(BEA称之为Logging Last Resource Transaction Option或LLR)。除了可以在XA事务中使用非XA资源外,这还是一种性能优化技术,因为XA驱动程序一般来说没有非XA驱动程序效率高,而且由于 网络通信量和磁盘IO,XA协议本身也给系统增加了开销。

WebLogic 9中的LLR特性不应该与“Emulate Two-Phase Commit(模拟两阶段提交)”相混淆,后者是以前版本的JDBC连接池层的选项。两者之间有着微妙而重要的区别。根据BEA WebLogic 8的说明文档:

当选中Emulate Two-Phase Commit for non-XA Driver选项(EnableTwoPhaseCommit设为true)时,非XA的JDBC资源通常在调用 XAResource.prepare() 方法时返回XA_OK。该资源试图提交或回滚它的本地事务以响应随后的XAResource.commit() 或XAResource.rollback() 调用。如果该资源提交或回滚失败,就会产生一个启发式错误。其结果是应用程序的数据可能会不一致。

可以看出,Emulate Two-Phase Commit的行为与LLR完全不同,而且使用时可能产生更多的启发式错误。

有许多不同的处理分布式事务的方法,而能够选择总是不错的。知道自己的数据库和事务管理器特性是值得的。如果您想了解一下包括JTA的事务处理理论和实 践,我推荐一本很不错的书,Mark Little与人合著的“Java Transaction Processing : Design and Implementation”。

  

评论
Dimitri,
我想LLR的要点在WebLogic 9.0 beta版JDBC的说明文档中有,并且按计划不久就会更新更详细的说明文档(可能与将要发布的WebLogic 9.0完全版本同时进行)。

最关键的一点是LLR具有完全的ACID(原子性、一致性、隔离性和永久性),而不像BEA和其他应用服务器供应商已经使用了很久的标准的last- participant-optimization(最近参与者优化)(又称为last-agent-optimization(最近代理优化))。

对于JDBC LLR,特定的JTA事务中应用程序的所有SQL工作都透明地指向同一个物理JDBC连接,而这个JDBC连接又维持着一个JDBC本地事务。在事务的持 续时间内,事务中标准的JDBC getConnection()应用程序调用隐式地保留了该连接(及其本地事务),将其置于事务管理器(TM)的控制之下。随后同一个事务的 getConnection() 应用程序调用隐式地创建了一个虚拟的连接,它又指回已保留的连接。如果JTA事务变成两阶段的(如果有非LLR资源参与,JTA LLR事务就会变成两阶段的),TM将使用该连接和本地事务存储一个2PC事务记录到数据库中,同时JTA基于事务处理日志“提交”而不是存储记录到一个 文件中,大多数情况下都是这样。下面是LLR提交2PC事务时的算法:

1 TM基于所有参与的非LLR资源(如JMS服务器)调用prepare,如果有任一个资源返回“no”的话,就回滚所有的LLR和非LLR资源。
2 TM使用事务中已保留的JDBC连接和本地事务向数据库中的“LLR表”写入一个2PC记录。每个WebLogic服务器只创建一个“LLR表”。(如果这一步失败,TM将回滚所有的工作)
3 TM使用JDBC本地提交提交JDBC连接,并释放(关闭)JDBC连接,这样在一个本地事务中既提交了2PC记录注入,又提交了应用程序的SQL工 作。(如果这一步失败,TM将测试数据库,看它是否存有2PC记录。如果找不到2PC记录,那么数据库工作肯定经过回滚,TM就回滚非LLR资源;否则, 数据库工作肯定已经提交了,所以TM继续提交其余的资源)
4 如果3顺利完成,TM就提交非LLR资源。
5 在4完成后,TM最终删除2PC记录。
如果应用服务器在事务的某一个时间点崩溃,2PC记录的有无将决定事务的结果,并被用来促成事务的完成。在崩溃恢复时,若没有2PC记录,那么事务就必须回滚所有参与的资源;而如果有2PC记录,事务就必须提交所有参与的资源。

发表人:barnes,2005年7月18日,11:28 PM

Tom,
感谢您的评论。是否有更详细地描述这种行为的BEA说明文档?

您描述得不是很清楚,至少对于我来说是这样的。到底“TLOG记录”保存在数据库中的什么地方?是否有专门针对它的表格,或者说它是如何保存的?我认为数据库是不知道事务协调程序的,而且也没有参与XA事务。您能更详细地说明一下吗?谢谢。

发表人:maximdim,2005年6月24日,10:16 AM

新闻报道:
“WebLogic Server将从版本9开始支持Last Resource Commit优化(BEA称之为Logging Last Resource Transaction Option或LLR)”。

以前版本的Weblogic对last resource commit优化的支持体现在resource adapter应用程序(也称为Connector)的选项中。

WebLogic所独有的新增的9.0 JDBC Logging Last Resource (LLR)特性与标准的last resource commit (LRC)完全不同,而且要比后者安全得多。

理论上,LLR与完全的XA一样安全。这是因为,LLR两阶段事务与LRC不同,事务管理器的两阶段提交记录(TLOG记录)与应用程序的JDBC工作存储在数据库中的同一个本地事务。这消除

MS DTC 是Microsoft 为Microsoft Windows 系统提供的分布式事务处理工具。MS DTC 使用Microsoft 推出的久经考验的事务处理技术来支持XA 功能,例如完整的两步分布式

 

JDBC事务和JTA (XA)事务
事务简介
  一般情况下,J2EE应用服务器支持JDBC事务、JTA(Java Transaction API)事务(一般由容器来进行管理)。通常,最好不要在程序中同时使用上述三种事务类型,比如在JTA事务中嵌套JDBC事务。第二方面,事务要在尽可 能短的时间内完成,不要在不同方法中实现事务的使用(事务的嵌套要求更加良好的设计)。

JDBC事务
  在JDBC中怎样将多个SQL语句组合成一个事务呢?在JDBC中,打开一个连接对象Connection时,缺省是auto-commit模式,每 个SQL语句都被当作一个事务,即每次执行一个语句,都会自动的得到事务确认。为了能将多个SQL语句组合成一个事务,要将auto-commit模式屏 蔽掉。在auto-commit模式屏蔽掉之后,如果不调用commit()方法,SQL语句不会得到事务确认。在最近一次commit()方法调用之后 的所有SQL会在方法commit()调用时得到确认。例如下面的代码:
/**
* 测试Jboss中的JDBC事务
*

@author javer QQ:84831612


* @date 2005
*/
jjava.sql.Connection conn = null;
try{
javax.sql.DataSource ds = (javax.sql.DataSource) context.lookup("java:/OracleDS");
conn = ds.getConnection();
conn.setAutoCommit(false);
java.sql.Statement statement = conn.createStatement();
/**
*
* 数据库操作
*
*/
conn.commit();
} catch (Exception e) {
if(conn!=null)
try{conn.rollback();}catch(Exception e1){out.println("catch:事务回滚失败!
");}
out.println("catch:" + e.getClass() + ";" + e.getMessage()+"
");
}finally{
if(conn!=null)
try{conn.close();}catch(Exception e1){out.println("finally:关闭数据库连接失败!
");}
}
  毕竟JDBC事务大多数程序员可能经常使用,而且比较相对简单,就不作过多的描述了


JTA (XA)事务
  Java 事务 API(JTA) 及其同门兄弟 Java 事务服务(Java Transaction Service JTS)为 J2EE 平台提供了分布式事务服务。一个分布式的事务涉及一个事务管理器和一个或者多个资源管理器。一个资源管理器是任何类型的持久性的数据存储。事务管理器负责 协调所有事务参与者之间的通信。
  与本地事务相比,XA 协议的系统开销相当大,因而应当慎重考虑是否确实需要分布式事务。只有支持 XA 协议的资源才能参与分布式事务。如果事务须登记一个以上的资源,则需要实现和配置所涉及的资源(适配器、JMS 或 JDBC 连接池)以支持 XA。

JTA事务工作流程
  WEB服务器(比如:WebLogic Server)将根据以下条件返回不同种类的包装器:

    1、所使用的 JDBC 驱动程序类是否支持 XA
    2、是从 DataSource 还是从 TxDataSource 获得连接
    3、调用 getConnection() 时是否在事务内运行
    4、是否通过 RMI 从远程获得连接

  决定返回哪种包装器的算法的工作方式如下:



JTA实例代码
/**
* 测试Jboss中的JTA事务
*

@author javer QQ:84831612


* @date 2005
*/
javax.transaction.UserTransaction tx = null;
java.sql.Connection conn = null;
try{
tx = (javax.transaction.UserTransaction) context.lookup("java:comp/UserTransaction");  //取得JTA事务,本例中是由Jboss容器管理
javax.sql.DataSource ds = (javax.sql.DataSource) context.lookup("java:/XAOracleDS");  //取得数据库连接池,必须有支持XA的数据库、驱动程序
tx.begin();
conn = ds.getConnection();
//conn.setAutoCommit(false);
java.sql.Statement statement = conn.createStatement();
String sql = "insert into testtable (cell1,cell2,cell3,cell4) values('"+System.currentTimeMillis()+"','','','')";
int insert = statement.executeUpdate(sql);
//conn.commit();  //JTA事务中不要嵌套JDBC事务啦!!!重要,切记,否则会抛出异常!!!
out.println("插入了" + insert + "行记录!
");
if(true)throw new Exception("故意抛出的异常!");
int num = statement.executeUpdate("delete testtable");
out.println("删除了" + num + "行记录!
");
tx.commit();
} catch (Exception e) {
if(tx!=null)
try{tx.rollback();}catch(Exception e1){out.println("catch:事务回滚失败!
");}
out.println("catch:" + e.getClass() + ";" + e.getMessage()+"
");
}finally{
if(conn!=null)
try{conn.close();}catch(Exception e1){out.println("finally:关闭数据库连接失败!
");}
}

分享到:
评论

相关推荐

    xa分布式事务处理

    分布式事务处理是解决多数据库系统中一致性问题的关键技术,而X/Open Distributed Transaction Processing (DTP)模型和XA规范是这一领域的重要理论基础和实现标准。X/Open组织,现称为Open Group,于1994年提出了DTP...

    WebSphere MQ与Oracle 数据库的XA事务(两阶段提交)实现

    XA事务是一种两阶段提交(Two-Phase Commit, 2PC)协议,广泛应用于多资源协调的分布式系统中。 首先,让我们了解一下MQ独立事务。在WebSphere MQ中,每个消息发送或接收操作都可以作为一个事务进行。这意味着如果...

    JDBC事务和JTA(XA)事务

    JDBC事务和JTA(XA)事务 JDBC事务和JTA(XA)事务是两种常见的数据库事务类型,它们都可以用来管理数据库事务,确保数据库的一致性和可靠性。 JDBC事务 JDBC事务是Java Database Connectivity(JDBC)的事务机制,它...

    mysql分布式事务实现 MySQL XA pdf

    #### 二、什么是分布式事务处理(DTP) 分布式事务处理(Distributed Transaction Processing, DTP)是一种确保在多个物理分布的数据库之间保持数据一致性的方法。这种一致性通常涉及到多个数据库节点同时成功或失败地...

    MySQL 外部XA及其在分布式事务中的应用分析

    在MySQL数据库中,XA事务通过两阶段提交协议(2PC)来协调分布式事务。该协议要求事务资源管理器(通常指数据库实例)在进行全局提交前,先达到一种“准备提交”的状态,并在所有参与方同意后,才能完成事务提交。...

    Mysql事务控制(XA分布式事务)和锁定语句

    1. **预提交阶段(Prepare Phase)**:在这一阶段,所有参与的资源管理器(RMs)会被事务管理器(TM)通知准备提交事务。RMs将记录必要的事务信息,以备后续的提交或回滚操作。 2. **提交或回滚阶段(Commit or ...

    掌握分布式事务的艺术:深入MySQL XA事务处理

    XA 事务是基于 X/Open XA 规范的一种分布式事务处理机制。这种机制允许应用程序在一个全局事务中协调多个资源管理器(如数据库、消息队列等),从而确保事务的一致性和完整性。具体来说,XA 协议通过两阶段提交(Two...

    分布式事务常用的解决方案,XA,Saga,TCC,MQ补偿.docx

    如果 Saga事务中的任何一个小事务失败,整个Saga事务都会回滚。Saga事务可以确保分布式事务的一致性和可靠性,但是它的实现复杂度较高。 TCC(Try-Confirm-Cancel)是指分布式事务处理的补偿事务模型。TCC事务由三...

    分布式事务分类,xa,at,tcc,sega

    **2PC**(Two-Phase Commit Protocol)是一种经典的分布式事务协议,主要用于数据库层面的分布式事务场景。它包括以下角色和步骤: - **角色**: - **事务协调者**(Coordinator):负责向参与者发送指令,收集...

    使用Atomikos处理ActiveMQ在Spring环境的XA事务

    XA事务是一种两阶段提交(2PC)协议,用于协调跨多个资源管理器(如数据库、消息队列等)的事务。这种事务模型确保了全局的一致性和原子性,即使在分布式系统中也能保证数据的一致性。 在Spring框架中,Atomikos...

    XA与非XA驱动差异

    - **XA驱动**:XA(Extended Architecture)驱动是JDBC的一种特殊类型,用于支持分布式事务处理。它实现了X/Open XA规范,能够处理跨多个资源管理器的事务。当应用程序需要同时操作多个数据库或其他资源时(例如消息...

    Distributed Transaction Processing The XA Specification.pdf

    1. 分布式事务处理模型:XA规范定义了一个分布式事务处理模型(X/Open DTP Model),它将事务处理过程中的不同组件之间的接口进行了标准化。该模型包括了应用程序、事务管理器、资源管理器和通信资源管理器。 2. ...

    JMS MDB 与 XA 事务-002

    2. `<message-driven>`元素:配置MDB的详细信息,包括JMS连接工厂引用和目的地引用,这些工厂和目的地通常需要支持XA事务。 3. `<xa-resource-manager>`元素:在WebLogic的扩展配置中,可能需要配置支持XA的资源管理...

    DTP分布式事务处理规范XA.pdf

    在第二阶段,根据第一阶段的反馈,事务管理器指示所有资源管理器实际提交或回滚事务。这种机制旨在防止因部分提交导致的数据不一致。 总之,《X/Open分布式事务处理规范XA》是分布式系统中确保数据一致性和事务完整...

    分布式事务之Seata XA AT实战代码

    Seata支持AT(Automatic Transaction)、TCC(Try-Confirm-Cancel)、SAGA以及二阶段提交(2PC)等多种分布式事务模式。本文将重点介绍Seata的XA和AT模式,并结合实战代码进行解析。 分布式事务的挑战在于协调多个...

    XA 多数据源分布式事物实现 java

    在分布式系统中,数据一致性是至关重要的,而XA(eXtended Architecture)协议就是为了解决这个问题而设计的一种两阶段提交(2PC, Two-Phase Commit)协议。本项目"XA 多数据源分布式事物实现 java"提供了一个基于...

    Distributed Transaction Processing-The XA+ Specification Version 2

    《分布式事务处理:XA+ 规范版本2》是X/Open组织发布的一份关于分布式事务处理的重要规范文档,该文档详细介绍了分布式事务处理模型以及相关的接口定义。X/Open作为一个国际性的标准化组织,在信息技术领域尤其是...

    DRDS跨库事务文档

    - **Try阶段**:尝试执行业务操作,这一步骤是事务的准备阶段,会检查条件,预留资源等,并且可能会失败导致事务回滚。例如,判断账户余额是否足够进行扣款操作。 - **Confirm阶段**:确认执行业务操作,这一步骤是...

    Distributed Transaction Processing The XA Specification

    《Distributed Transaction Processing: The XA Specification》是一份重要的技术文档,详细阐述了分布式事务处理的规范,特别是 XA 协议。在 Java 开发中,理解并掌握 XA 规范对于构建高可用、可扩展的分布式系统至...

Global site tag (gtag.js) - Google Analytics