博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JTA(XA)原理解析
阅读量:4199 次
发布时间:2019-05-26

本文共 1534 字,大约阅读时间需要 5 分钟。

昨天讲了java事务,由于Transaction(事务) 分两种

Local Transaction 和 Global Transaction

涉及到一个Connection的Commit,称为Local Transaction
涉及到多个Connection的Commit,称为Global Transaction

Local Transaction用JDBC事务实现是没有问题,然而Global Transaction的实现就无法保证了,所以不得不了解下JTA的神奇,但其实这样的事务也是存在问题的,下面将指出

 

XA需要两阶段提交 -- prepare 和 commit.

假设有两个Connection, con1, con2, 大体的过程如下 
 

在XAResouce1 and 2 commit的时候,

可能XAResouce1 commit() 成功了,XAResouce2 commit()失败了。
这时候,会抛出一个 “启发式异常”。程序可以处理这个异常。比如,XAResouce.recover()之类。
但一般情况下,还真没别的办法,需要数据管理员根据数据操作日志 undo所有的操作,或者恢复数据备份。
有的数据库在进行数据操作的时候,会生成一个“反操作”日志。比如,insert 对 delete, 等。 

 

Global Transaction 需要XA接口(包括在JTA里面)的支持。

import javax.sql.XAConnection;

import javax.transaction.xa.Xid;
import javax.transaction.xa.XAResource;
import javax.transaction.xa.XAException;
import javax.transaction.Transaction;
import javax.transaction.TransactionManager;

其中的

javax.sql.XAConnection;
javax.transaction.xa.Xid;
javax.transaction.xa.XAResource;

这些XA接口的实现,需要数据库的JDBC提供。

数据库本身要支持XA。数据库的JDBC也要提供XA的实现。

Oracle, Sybase, DB2, SQL Server等大型数据库支持XA

免费的postreSQL也支持XA 

My SQL 连Local Transaction都支持不好,更别说Global Transation了。

 

TransactionManager的实现能够处理多个XAResouce(一个XAResouce list)的情况。

比如Tyrex。或JBoss等EJB Server的Transaction实现代码  

 

 

下面转载一篇讲解XA的详细原理解析  共分3部分,讲的很不错,找个机会我将翻译下

你可能感兴趣的文章
ebay 沙盒账号注册
查看>>
linux -8 Linux磁盘与文件系统的管理
查看>>
linux -8 Linux磁盘与文件系统的管理
查看>>
linux 9 -文件系统的压缩与打包 -dump
查看>>
PHP在变量前面加&是什么意思?
查看>>
ebay api - GetUserDisputes 函数
查看>>
ebay api GetMyMessages 函数
查看>>
wdlinux
查看>>
关于mysql升级到5.5报错问题
查看>>
magento - 通过storeid,分类id,天数(几天内)得到产品
查看>>
一个很不错的bash脚本编写教程,至少没接触过BASH的也能看懂!
查看>>
Redis和Memcache对比及选择
查看>>
用谷歌账号登陆magento、
查看>>
php oauth 模块在linux下安装
查看>>
代替nginx的服务器 - The Tengine Web Server
查看>>
nginx 升级成 tengine 的代码
查看>>
magento rest api 调用
查看>>
magento rest api 调用!
查看>>
magento rest api get Token key and secret
查看>>
谷歌获取货币汇率代码
查看>>