全局和本地事务(从理论上)
来源:互联网 发布:山东齐鲁网络电视台 编辑:程序博客网 时间:2024/04/28 20:16
全局和本地事务
· 全局事务 - 资源管理器管理和协调的事务,可以跨越多个数据库和进程。资源管理器一般使用 XA二阶段提交协议与“企业信息系统”(EIS) 或数据库进行交互。
· 本地事务 - 在单个 EIS 或数据库的本地并且限制在单个进程内的事务。本地事务不涉及多个数据来源。
本地和全局事务都使用 javax.transaction.UserTransaction 接口划分界限,客户端必须使用此接口。本地事务不使用事务管理器,因而处理速度更快。
起初,所有事务都是本地的。如果非 XA 数据源连接是事务范围中登记的第一个资源连接,当“另一个”XA 数据源连接加入此连接时,该非 XA 数据源连接就成为全局事务。如果另一个非 XA 数据源连接试图加入,就会产生异常。
J2EE开发者有两个事务管理的选择: 全局 或 本地 事务。全局事务由应用服务器管理,使用JTA。局部事务是和资源相关的,比如一个和JDBC连接关联的事务。这个选择有深刻的含义。例如,全局事务可以用于多个事务性的资源(典型例子是关系数据库和消息队列)。使用局部事务,应用服务器不需要参与事务管理,并且不能帮助确保跨越多个资源(需要指出的是多数应用使用单一事务性的资源)的事务的正确性。
全局事务. 全局事务有一个重大的缺陷,代码需要使用JTA:一个笨重的API(部分是因为它的异常模型)。此外,JTA的UserTransaction通常需要从JNDI获得,这意味着我们为了JTA,需要 同时 使用JNDI和 JTA。显然全部使用全局事务限制了应用代码的重用性,因为JTA通常只在应用服务器的环境中才能使用。 以前,使用全局事务的首选方式是通过EJB的 CMT(容器管理事务):CMT是 声明式事务管理 的一种形式(区别于 编程式事务管理)。EJB的CMT不需要任何和事务相关的JNDI查找,虽然使用EJB本身肯定需要使用JNDI。它消除了大多数(不是全部)硬编码的方式去控制事务。重大的缺陷是CMT绑定在JTA和应用服务器环境上,并且只有我们选择使用EJB实现业务逻辑,或者至少处于一个事务化EJB的外观(Facade)后才能使用它。EJB有如此多的诟病,尤其是存在其它声明式事务管理时,EJB不是一个吸引人的建议。
本地事务. 本地事务容易使用,但也有明显的缺点:它们不能用于多个事务性资源。例如,使用JDBC连接事务管理的代码不能用于全局的JTA事务中。另一个缺点是局部事务趋向于入侵式的编程模型。
- 全局和本地事务(从理论上)
- 全局事务和本地事务
- 全局事务 与 本地事务
- hibernate本地事务、全局事务
- 全局事务与本地事务
- 全局事务与本地事务的区别应用(从代码方面来探讨的)
- 全局事务和局部事务
- Java中的事务——全局事务与本地事务
- 全局事务与本地事务的区别应用
- 全局事务与本地事务的区别应用
- 全局事务与本地事务的区别应用
- 全局事务与本地事务的区别应用
- 全局事务与本地事务的区别应用
- 全局事务与本地事务的区别应用
- 本地和全局负载均衡
- 全局引用和本地引用
- 本地事务和分布式事务工作实践
- 本地事务和分布式事务工作实践
- [LeetCode] Combination Sum II
- 全局事务与本地事务的区别应用(从代码方面来探讨的)
- src或者href值为base64编码代码
- C++ primer 课后习题 第五章
- 【Android】Animation之改变自带的Activity切屏效果
- 全局和本地事务(从理论上)
- 黑马程序员 java基础_Socket
- 2080CRM客户关系管理系统
- 解决iText 5.0.1,加入iTextAsian.jar 出现异常 Font 'STSong-Light' with 'UniGB-UCS2-H'
- UVa 674 Coin Change (完全背包&最优解的方案数)
- poj1141
- 【转】最短的崩溃程序(C语言版)
- 让app在ios6上具有ios7的扁平效果
- Linux 文件