热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

分布式事务之XA方案

分布式事务XA学习视频什么是XAXA方案是XOPEN组织定义的一种分布式事务处理标准,在阿里巴巴seata定义的分布式事务框架内,利用事务资源对XA协议的支持(即利用数据库支持

分布式事务XA学习视频


什么是XA

XA方案是X/OPEN组织定义的一种分布式事务处理标准, 在阿里巴巴seata定义的分布式事务框架内, 利用事务资源对XA协议的支持(即利用数据库支持XA协议 比如关系型数据库mysql,oracle等等) , 以XA协议的机制来管理事务分支的一种两段式方案。


XA的流程

XA的两个阶段示意图


  • 三个角色(TM, RM, TC)
    TM : 事务管理器, 即开启全局事务的角色, 用来划定分布式事务的边界和范围。
    RM : 资源管理器, 即针对数据库进行具体操作的角色。
    TC : 全局事务协调者, 用于事务注册, 全局事务提交, 全局事务回滚。
  • 总体流程
    1.TM向TC注册全局事务
    2.调用各资源管理器(即对各数据库数据进行操作), RM向TC注册分支事务, 此时sql会暂存,不会立即提交
    3.TM向TC下达全局事务提交, 此时TC会依次执行sql
    4.如果有分支事务失败了,则会对之前提交的sql进行回滚

代码示意

在这里插入图片描述
在这里插入图片描述


XA的优势


  • 基于CP设计, 保证了一致性
  • 主流的关系型数据库都对XA有支持
  • 两段式提交实现简单粗暴, 成熟稳定

XA的劣势


  • 数据阻塞, 执行效率低, 基于数据库事务处理, 被操作的数据会被hang住, 后续对该数据的操作会被阻塞, 高并发系统禁用。
  • 协议阻塞, 收到XA commit或 XA rollback 前,必须阻塞等待, 如果某一个RM"失联", TC会进行一系列重试, 其余RM资源会hang住, 等待超时回滚。
  • 所涉及的数据库必须支持XA协议。

适用场景


  • 低并发, 数据冲突较少的系统, 因为在全局事务未提交或回滚时, 涉及的数据会被hang住
  • 绝大多数系统都适用, 没多少系统有高并发场景

推荐阅读
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 探讨如何从数据库中按分组获取最大N条记录的方法,并分享新年祝福。本文提供多种解决方案,适用于不同数据库系统,如MySQL、Oracle等。 ... [详细]
  • 本文探讨了2012年4月期间,淘宝在技术架构上的关键数据和发展历程。涵盖了从早期PHP到Java的转型,以及在分布式计算、存储和网络流量管理方面的创新。 ... [详细]
  • Navicat Premium 15 安装指南及数据库连接配置
    本文详细介绍 Navicat Premium 15 的安装步骤及其对多种数据库(如 MySQL 和 Oracle)的支持,帮助用户顺利完成软件的安装与激活。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
author-avatar
长相守短相思洪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有