READ:分布式事务的两阶段提交

关于分布式事务的两阶段提交

 

 

 

        两阶段提交主要指的是数据库的分布式事务处理,需要数据库产品本身支持这个特性,目前的大型数据库一般都支持两阶段提交,比如Oracle、DB2等,但mysql不支持。传统的一个事务都是绑定在一个connection上的,所以,只要是想在两个connection上做一个统一的事务,就必须使用两阶段提交。

 

        比如,有两台数据库服务器A和B,有一个业务操作需要upate A上的一个数据库表记录,并同时update B上的一个数据库表记录。第一阶段提交时,JTA通知两个数据库做update操作,但不commit。两个数据库都做好准备后,反馈消息给JTA,JTA然后执行第二阶段提交,即同时通知两个数据库做commit操作,这样一个两阶段提交的事务就完成了。

 

        第二阶段提交还涉及到一个时间片长度和可能失效的问题,具体的技术细节还需要看资料。总的来说,两阶段提交是目前解决分布式事务的一个途径。不过,做分布式事务的效率比普通的事务处理要低很多。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值