分布式事务:

  分布式事务是处理多节点上 的数据保持 类似传统 ACID 事物特性的 一种事物。

XA:是一种协议,一种分布式事务的协议,核心思想是2段式提交。 1 准备阶段  2 提交阶段。XA协议是 Tuxedo 首先提出的

  

  XA 的 原理 ,XA分了 几个角色,RM ,TM ,AP 等

  RM:资源管理器。他记录着XA的 事物的全部 状态(在事物结算之前不会丢失)。

  XA事物成功的流程:

    1准备阶段 RM 告诉 相关的 几个 TM(事物管理器), 最一些事情,但是别提交。这时候修改数据还不可见(除了RM 以外或者说 TM外 不可见)

    2 如果所有的 TM都告诉 RM 我可以做这个事情。那么就 通知 所有 TM  commit

    3 如果所有的 TM commit 都成功,那么这个XA 事物完成。 RM 可以忘记关于这个XA事物的数据了。

  XA事物失败的流程:

    1准备阶段 RM 告诉 相关的 几个 TM(事物管理器), 最一些事情,但是别提交。

    2 如果任何一个TM  commit 告诉 RM 我不能执行( 预提交阶段就失败 )

    3 RM 通知 这个事物涉及到的 TM  rollback

  

  XA事物极端流程: 需要补偿机制(正常不会出,除非极端情况,因为前面预处理阶段已经把数据写入了,后面 commit 只是 修改一个状态 ,让别的事物可以读到 )

    1准备阶段 RM 告诉 相关的 几个 TM(事物管理器), 最一些事情,但是别提交。

    2 如果所有的 TM都告诉 RM 我可以做这个事情。那么就 通知 所有 TM  commit

    3 如果部分 TM commit 成功,只有一个失败了。因为 RM  记录了事物的完整信息。所以可以在 做一些补偿机制,比如包刚才的 失败部分 在做一次。

  

X/open: XA协议是 Tuxedo 首先提出XA ,并交给X/Open组织,作为资源管理器(数据库)与事务管理器的接口标准. 所以 X/open 是组织 XA 的 一个机构。

CAP :

  

CAP是三个理想的状态。但是只能3 选2 ,不能全部达到。

C:

  • Consistency 强一致性    描述数据要完全的一致,A加了 100,B 就减去100 。同时发生,一起发生。就是强一致性

A:

  • Availability 高可用 在一定的时间内正确的响应 客户端的请求。不会长时间等待挥着阻塞,不会 服务器不可用。

P:

  • Partition tolerance 分区容错性  分布式环境中如果出现了网络分区,依旧是可以正常工作。每次加入节点的变动都可以看做特殊网络分区。

  网络分区的解释:因为网络原因,集群节点部分 分成多块,每块之间的网络不能通信。

上面三个条件。在分布式环境中,网络分区,必然要考虑。所以P必选。 现在的分布式框架都是  CA 2 选1 +P。

 

2 段是事务:如果你是事务是 先预提交,然后在确认提交 分成2 段的就叫做2 段式事务。  比如 XA 协议规定的 分布式事务 就是2 段式事务。 比如 MQ 的预消息机制。 比如 给予mq 和 本地事务 实现的消息机制。

    mq 和 本地事务 实现的消息机制原理:  变 a b 两个 分布式子事物 为 插入 2 条 本地记录 一条消息A,和消息B,,如果 正常执行 A,B 两条插入记录被转个给 MQ ,如果 任何失败,A B被丢弃。

BASE:

  BASE是Basically Available(基本可用)、Soft state(软状态)和Eventually consistent(最终一致性)三个短语的缩写

  BASE理论是对CAP中一致性和可用性权衡的结果。我们不都舍弃,找一个折中 的办法。 不能同时拥有,也不想放弃任何一个。那就一个区一半吧。

  

  

  Basically Available(基本可用): 在异常的时候允许适当的延长响应时间。 在并发太高的时候允许部分不是成功,而且不是全部都堵死在哪里。

  Soft state(软状态): 可以存在中间状态: A +100, B -100 如果不能同时完成,那么就让 A +100 并且B冻结 记录里面 写入100 把。这样 一个转账中的状态。

  Eventually consistent(最终一致性): 上面的 中间状态不可能让他一直存在,最终我们会让他一致的,比如,修改同一个 余额字段 ,并发太高,那么就插入冻结记录。不用锁这个字段,但是最后我们要报这个冻结 在余额 里面扣掉(在系统缓,或者一个延时队列慢慢做)。

分布式解决方案实现原理:https://www.cnblogs.com/cxygg/p/9526401.html

分布式事务 XA 两段式事务 X/open CAP BASE 一次分清的更多相关文章

  1. 数据库分布式事务XA规范介绍及Mysql底层实现机制

    1. 引言 分布式事务主要应用领域主要体现在数据库领域.微服务应用领域.微服务应用领域一般是柔性事务,不完全满足ACID特性,特别是I隔离性,比如说saga不满足隔离性,主要是通过根据分支事务执行成功 ...

  2. MySQL binlog 组提交与 XA(分布式事务、两阶段提交)【转】

    概念: XA(分布式事务)规范主要定义了(全局)事务管理器(TM: Transaction Manager)和(局部)资源管理器(RM: Resource Manager)之间的接口.XA为了实现分布 ...

  3. 关于分布式事务、两阶段提交、一阶段提交、Best Efforts 1PC模式和事务补偿机制的研究 转载

    1.XA XA是由X/Open组织提出的分布式事务的规范.XA规范主要定义了(全局)事务管理器(Transaction Manager)和(局部)资源管理器(Resource Manager)之间的接 ...

  4. MySQL数据库分布式事务XA优缺点与改进方案

    1 MySQL 外部XA分析 1.1 作用分析 MySQL数据库外部XA可以用在分布式数据库代理层,实现对MySQL数据库的分布式事务支持,例如开源的代理工具:ameoba[4],网易的DDB,淘宝的 ...

  5. 一文教你迅速解决分布式事务 XA 一致性问题

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯云数据库团队 近日,腾讯云发布了分布式数据库解决方案(DCDB),其最明显的特性之一就是提供了高于开源分布式事务XA的性能.大型 ...

  6. XA: 事务和两阶段提交

    本文原文连接:http://blog.csdn.net/bluishglc/article/details/7612811 ,转载请注明出处! 1.XA XA是由X/Open组织提出的两阶段提交协议, ...

  7. DTP模型之一:(XA协议之三)MySQL数据库分布式事务XA优缺点与改进方案

    1 MySQL 外部XA分析 1.1 作用分析 MySQL数据库外部XA可以用在分布式数据库代理层,实现对MySQL数据库的分布式事务支持,例如开源的代理工具:ameoba[4],网易的DDB,淘宝的 ...

  8. 详解Mysql分布式事务XA(跨数据库事务)

    详解Mysql分布式事务XA(跨数据库事务) 学习了:http://blog.csdn.net/soonfly/article/details/70677138 mysql执行XA事物的时候,mysq ...

  9. Mysql数据库分布式事务XA详解

    XA事务简介 XA 事务的基础是两阶段提交协议.需要有一个事务协调者来保证所有的事务参与者都完成了准备工作(第一阶段).如果协调者收到所有参与者都准备好的消息,就会通知所有的事务都可以提交了(第二阶段 ...

随机推荐

  1. AtCoder F - Exhausted?

    传送门 sxy题解: //Achen #include<algorithm> #include<iostream> #include<cstring> #inclu ...

  2. IO流读取和写入文件

    package com.xmlmysql.demo.config; import java.io.BufferedReader; import java.io.BufferedWriter; impo ...

  3. 基于OneMap的水利行业共享服务平台搭建步骤

    今天上午再次学习Esri技术培训中心的“GIS服务共享与运维管理——之OneMap解决方案”课程,从中学习了OneMap的产品架构以及基于OneMap共享服务平台的搭建步骤.下面把其中水利行业的共享服 ...

  4. PAT甲级——A1091 Acute Stroke【30】

    One important factor to identify acute stroke (急性脑卒中) is the volume of the stroke core. Given the re ...

  5. Netty设置高低水位

    Configure high and low write watermarks   Server ServerBootstrap bootstrap = new ServerBootstrap(); ...

  6. 02_Spring Bean的装配模式_基于XML配置方式

    一.三种实例化Bean的方式 1.使用类构造器实例化(默认无参数) <bean id="bean1" class="com.demo1.Bean1"> ...

  7. C#跨域

    //在ConfigureServices中配置 #region 跨域 var urls = "*";//Configuration["AppConfig:Cores&qu ...

  8. font-size:100%

    font-size:100%;设置字体属性为默认大小,是相对于浏览器默认字体大小或继承body设定的字体大小来说的. 例如: h1,h2,h3,h4,h5,h6 {font-size:100%;fon ...

  9. Python学习之--函数/生成器/装饰器

    Function,函数,主要是为了:1提高代码的复用程度,2将程序模块化. 定义函数 在Python中,使用def 用来定义函数,一般函数的定义如下: def name(arg1,arg2,....) ...

  10. Cat- Linux必学的60个命令

    1.作用 cat(“concatenate”的缩写)命令用于连接并显示指定的一个和多个文件的有关信息,它的使用权限是所有用户. 2.格式 cat [options] 文件1 文件2…… 3.[opti ...