XA 与两阶段提交

本贴最后更新于 3433 天前,其中的信息可能已经斗转星移

先讲讲两阶段提交把,两阶段提交顾名思义分为两个阶段,一个是准备阶段,一个是提交阶段。

在两阶段提交中有三个参与者,一个是应用程序(向事务管理器提交 commit或者rollback请求),一个是事务管理器(接收应用程序的请求,并协调 多个资源管理器 进行事务提交或者回滚),还有一个就是 资源管理器咯(管理单个资源——数据库,JMS等的事务)

有一个经典的对两阶段的比喻,就是结婚的仪式:

牧师(事务管理器)分别询问新娘、新郎(资源管理器)你是否愿意与对方结婚(第一阶段开始),如果两个人都回答 I do(第一阶段结束,第二阶段开始),那么牧师就会向两位新人宣布,你们的婚姻关系成立了~(第二阶段结束)
如果有异常情况,有一个人say no的话,那么,就结不了婚啦~

两阶段提交的第一阶段存在的意义是 让对应的资源做好一切提交的准备,如果提交不了的话,可以尽快暴露出来(如磁盘空间不足什么的),告诉协调器,让大家一起回滚。

 

一些两阶段提交协议的实现里会有 “最后参与者支持(Last Participant Support)” 或者 “最后资源提交优化(Last Resource Commit Optimization)” 的支持,这个支持允许有 一个 非XA支持的资源参与到全局事务中来,具体是这么实现的~

还是结婚的栗子,不过我们假设中间多了个民政局(非XA资源),在新郎新娘都SAY I DO后(XA的第一阶段结束),牧师问民政局你是否愿意给他们颁发结婚证呀(让非XA资源提交),若民政局颁发证书了(非资源XA提交成功),牧师则宣布婚姻关系成立,若民政局说,你们是失散多年的亲兄妹!好吧,牧师只能说,你们的婚姻关系不成立,散了吧(XA资源回滚)。

上述这个优化项并不建议使用,因为在第一阶段和第二阶段之间必须串行的接入第三阶段,这就增加了事务执行的时间,有一句老话大家都知道的,叫夜长梦多,尤其是在这种网络环境,并且 这个实现 只是 一些 两阶段提交的实现中支持...请理解 一些 的含义...

 

当然,写两阶段协议实现的人都跟你我一样聪明,当事务参与者只有一个的时候,他会从两阶段提交变成一阶段提交,省去询问的提交准备的步骤

 

 

现在我们对两阶段提交有了一个大概整体的了解了,下面我们来分析一下本协议在网络环境中是如何保持一致性。

在协调者发出COMMIT前,参与者总是能通过ROLLBACK恢复到一致性状态的,在此,不再描述。我们着重描述进入 “第二阶段”, 协调者开始发送COMMIT命令的场景

有三个角色 协调者C 部分参与者A 部分参与者B ,A与B加起来就是所有参与者。3个元素任意自由组成组合,一个元素可归属多个组合,组合内元素能正常互访,不同组合元素无法互访(对方挂了,或者与对方的网络中断),那么有以下的组成:

一、总共只有一个组合的情况:

1、ABC三个组成一个组合,这表示ABC都能互相正常互联,两阶段提交正常运行

二、总共只有两个组合的情况:

1) C,AB——参与者可以询问包括自己在内的所有参与者 可提交状态,从而判定应该执行提交还是回滚的结果,从而保证强一致性及可用性。

2) CA,B——A的数据能够明确知道执行结果,能执行回滚或者提交,这部分保持着一致性及可用性。而B因为无从获得提交结果,因此只能阻塞。

3) CB,A——与2)类似。

4) CA,CB——AB都能获得最终的提交结果,能保证一致性。由于消息是可以传递的,因此这个组合等价于 “一、”中全部可互联的情况

5) AC,AB——A能够从C中获得最终的提交结果,B能够从A中获得最终提交结果,因此最终能达到强一致性也保证了可用性。本质上跟4)一致。由于消息是可以传递的,因此这个组合等价于 “一、”中全部可互联的情况

6) BC,BA——与4)类似

总共只有三个组合的情况:

1)A,B,C——好吧,肯定都阻塞,没有异议把....

2)其他的组合……——存在三个或以上的组合的话,无论怎么分通过消息传递后都必然等价于上述已经存在的情况,无需再讨论

 

因此,总结一下,两阶段提交在 部分资源管理器 无法与 协调者互联 且无法与 其他资源管理器互联时,只能阻塞等待 互联恢复,完全失去了 可用性。但在其他情况下,还是能较好的处理异常,消耗部分可用性(从其他资源管理器中获得提交结果,增加了耗时)来维持一致性的。

 

 

好吧,到现在两阶段提交的概念以及一些异常的处理应该都讲的差不多了,那么XA与两阶段提交是啥关系?其实关系很简单,可能大家都猜出来了,XA是基于两阶段提交设计的一个接口标准,实现了这个XA接口的资源管理器那么就能参与到XA管控的全局事务中~好咯,本章完毕 ~

 

 

 

 

 

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖 • 2 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    7 引用 • 28 回帖 • 1 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 651 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 475 关注
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    5 引用 • 34 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 185 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    89 引用 • 150 回帖
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 140 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    84 引用 • 414 回帖
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 616 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    337 引用 • 324 回帖 • 2 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 834 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1284 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    38 引用 • 158 回帖 • 1 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    34 引用 • 37 回帖 • 555 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    135 引用 • 798 回帖
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 40 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 443 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 675 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    187 引用 • 1021 回帖 • 1 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    188 引用 • 832 回帖
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 2 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 81 关注