最新要闻
- 华为首次下放卫星通信!nova 11系列上架预约:下周一发布
- 【焦点热闻】美方以涉俄为由将多家中国企业列入清单实施制裁,商务部回应
- 【播资讯】史上最大屏!苹果15英寸MacBook Air确认搭载M2芯片:6月发布
- 医院回应护士上班戴美甲给患者扎针:已让其卸掉!专业人士科普
- 地产网红称没几千万怎么叫人才引热议:网友称价值观扭曲 谁钱多谁就是人才?
- 万元买手机很难吗?中美日韩等1月销量TOP 5:iPhone完爆安卓
- 世界热推荐:国内油价17日料上调 部分地区95号汽油或重返“8元时代”
- 世界最资讯丨CPU买散片还是盒装 DIY老鸟:怎么选都是错!
- 当前视讯!沙特俄罗斯等减产后!国内新一轮油价调整将至 或重返8元时代
- 全球观天下!民声丨合理优化社区规模 提升社会服务质量
- 环球热门:诚意十足!国产科幻FPS《边境》制作组24小时直播修BUG
- 环球观速讯丨00后网红马若松遇车祸身亡监控曝光:面包车双实线掉头致追尾
- 当前速递!性能残血还带风扇 海盗船PCIe 5.0硬盘开卖:性价比竟然很高
- 世界今日讯!诺基亚一个暗箱操作 给华为喂了口九转大肠
- 天天快报!小米13 Ultra全曝光 核心配置已无悬念
- 苹果手机无法下载app什么原因_苹果手机无法下载app是什么原因
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
播报:分布式事务--Seata
- 分布式事务--Seata
- 一、事务的ACID原则
- 二、CAP定理
- 三、BASE理论
- 四、分布式事务模型
- 五、Seata架构
- 六、XA模式原理
- 6.1 seata的XA模式
- 6.2 seata的XA的优缺点
- 6.3 实现XA模式
- 七、AT模式原理
- 7.1 AT模式的脏写问题
- 7.2 AT模式的写隔离
- 7.3 AT模式的优缺点
- 八、TCC模式原理
- 8.1 TCC模式举例
- 8.2 TCC模式优缺点
- 8.3 TCC的空回滚和业务悬挂
- 九、Saga模式
- 9.1 Saga模式优缺点
- 十、四种模式对比
分布式事务--Seata
Seata是分布式事务解决方案。致力于提供高性能和简单易用的分布式事务服务,为用户打造一站式的分布式解决方案。官网地址:http://seata.io/,其中的文档、播客中提供了大量的使用说明、源码分析。
一、事务的ACID原则
在分布式系统下,一个业务跨越多个服务或数据源,每个服务都是一个分支事务,要保证所有分支事务最终状态一致,这样的事务就是分布式事务。
(资料图片)
原子性 | 事务中的所有操作,要么全部成功,要么全部失败 |
---|---|
一致性 | 要保证数据库内部完整性约束、声明性约束 |
隔离性 | 对同一资源操作的事务不能同时发生 |
持久性 | 对数据库做的一切修改将永久保存,不管是否出现故障 |
二、CAP定理
分布式系统节点通过网络连接,一定会出现分区问题(P);当分区出现时,系统的一致性(C)和可用性(A)就无法同时满足。
分布式系统有三个指标:
- Consistency(一致性):用户访问分布式系统中的任意节点,得到的数据必须一致。
- Availability(可用性):用户访问集群中的任意健康节点,必须能得到响应,而不是超时或拒绝。
- Partition tolerance (分区容错性)
- Partition(分区):因为网络故障或其它原因导致分布式系统中的部分节点与其它节点失去连接,形成独立分区。
- Tolerance(容错):在集群出现分区时,整个系统也要持续对外提供服务。
三、BASE理论
1.BASE理论是对CAP的一种解决思路,包含三个思想:
- Basically Available (基本可用):分布式系统在出现故障时,允许损失部分可用性,即保证核心可用。
- Soft State(软状态):在一定时间内,允许出现中间状态,比如临时的不一致状态。
- Eventually Consistent(最终一致性):虽然无法保证强一致性,但是在软状态结束后,最终达到数据一致。
2.分布式事务最大的问题是各个子事务的一致性问题,因此可以借鉴CAP定理和BASE理论:
- AP模式:各子事务分别执行和提交,允许出现结果不一致,然后采用弥补措施恢复数据即可,实现最终一致。
- CP模式:各个子事务执行后互相等待,同时提交,同时回滚,达成强一致。但事务等待过程中,处于弱可用状态。
四、分布式事务模型
解决分布式事务,各个子系统之间必须能感知到彼此的事务状态,才能保证状态一致,因此需要一个事务协调者来协调每一个事务的参与者(子系统事务)。
1.解决分布式事务的模型
- 分支事务:子系统事务;分布式事务中包含的每个子系统的事务。
- 全局事务:有关联的各个分支事务的集合;整个分布式事务。
2.解决分布式事务的思想
- 最终一致思想:各分支事务分别执行并提交,如果有不一致的情况,再想办法恢复数据。
- 强一致思想:各分支事务执行完业务不要提交,等待彼此结果。而后统一提交或回滚。
五、Seata架构
1.Seata事务管理中有三个重要的角色:
- TC (Transaction Coordinator) - 事务协调者:维护全局和分支事务的状态,协调全局事务提交或回滚。
- TM (Transaction Manager) - 事务管理器:定义全局事务的范围、开始全局事务、提交或回滚全局事务。
- RM (Resource Manager) - 资源管理器:管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。
2.Seata提供了四种不同的分布式事务解决方案:
- XA模式:强一致性分阶段事务模式,牺牲了一定的可用性,无业务侵入。
- TCC模式:最终一致的分阶段事务模式,有业务侵入。
- AT模式:最终一致的分阶段事务模式,无业务侵入,也是Seata的默认模式。
- SAGA模式:长事务模式,有业务侵入。
3.nacos服务名称组成包括?
namespace(命名空间) + group(分组名称) + serviceName(服务名称) + cluster(区域)。
4.seata客户端获取tc的cluster名称方式?
以tx-group-service
的值为key到vgroupMapping
中查找。
六、XA模式原理
XA 规范是 X/Open 组织定义的分布式事务处理(DTP)标准,XA 规范描述了全局的TM与局部的RM之间的接口,几乎所有主流的数据库都对 XA 规范提供了支持。
6.1 seata的XA模式
RM一阶段的工作:
- 注册分支事务到TC
- 执行分支业务sql但不提交
- 报告执行状态到TC
TC二阶段的工作:
- TC检测各分支事务执行状态
- 如果都成功,通知所有RM提交事务
- 如果有失败,通知所有RM回滚事务
RM二阶段的工作:
- 接收TC指令,提交或回滚事务
6.2 seata的XA的优缺点
XA模式的优点:
- 事务的强一致性,满足ACID原则
- 常用数据库都支持,实现简单,并且没有代码侵入
XA模式的缺点:
- 因为一阶段需要锁定数据库资源,等待二阶段结束才释放,性能较差
- 依赖关系型数据库实现事务
6.3 实现XA模式
Seata的starter已经完成了XA模式的自动装配,实现非常简单,步骤如下:
- 修改application.yml文件(每个参与事务的微服务),开启XA模式。
- 给发起全局事务的入口方法添加@GlobalTransactional注解。
- 重启服务并测试。
七、AT模式原理
AT模式同样是分阶段提交的事务模型,不过缺弥补了XA模型中资源锁定周期过长的缺陷。
阶段一RM的工作:
- 注册分支事务
- 记录undo-log(数据快照)
- 执行业务sql并提交
- 报告事务状态
阶段二提交时RM的工作:
- 删除undo-log
阶段二回滚时RM的工作:
- 根据undo-log恢复数据到更新前
AT模式与XA模式最大的区别:
- XA模式一阶段不提交事务,锁定资源;AT模式一阶段直接提交,不锁定资源。
- XA模式依赖数据库机制实现回滚;AT模式利用数据快照实现数据回滚。
- XA模式强一致;AT模式最终一致
7.1 AT模式的脏写问题
在并发的情况下,事务一执行RM第一阶段
- 1.1.获取DB锁,保存快照
- 1.2.执行业务
- 1.3.提交事务,释放DB锁
这时DB锁释放,事务二得到DB锁,执行RM第一阶段
- 1.1.获取DB锁,保存快照
- 1.2.执行业务
- 1.3.提交事务,释放DB锁
后面被事务一获取DB锁,根据快照恢复数据,这时将快照恢复,导致事务二的操作白干了,造成数据安全性问题,隔离性没有得到保障。
7.2 AT模式的写隔离
全局锁:由TC记录当前正在操作某行数据的事务,该事务持有全局锁,具备执行权。
在并发的情况下,事务一执行RM第一阶段
- 1.1.获取DB锁(数据库锁),保存快照
- 1.2.执行业务
- 此时获取全局锁
- 1.3.提交事务,释放DB锁
这时DB锁释放,事务二得到DB锁,执行RM第一阶段
- 1.1.获取DB锁,保存快照
- 1.2.执行业务
- 此时获取全局锁,但由于事务一已经获取重试,默认30次,间隔10毫秒
- 1.4.任务超时,回滚并释放DB锁
而这时事务一
- 等待DB锁
- 2.1.获取DB锁,根据快照恢复数据
- 释放全局锁
由于DB锁的等待时间比全局锁久,所以事务一可以等待事务二任务超时,回滚并释放DB锁,但还是有局限,全局锁只能共同作用于seata的事务,不是seata的管理全局事务也可以修改seata的字段。
解决办法
1.1.事务一获取DB锁,保存快照 --> before-imag
1.2.事务一执行业务s --> after-image(执行完后再生成一个快照)
在这种极端的情况下,非seata的管理全局事务修改seata的字段,提交事务,释放DB锁
这时事务一在2.1.获取DB锁,根据快照恢复数据,对比一下此时数据库的字段数据是否被修改过,与 after-image 进行比较即可,再释放全局锁。
2.2.记录异常,发送警告,人工介入
7.3 AT模式的优缺点
AT模式的优点:
- 一阶段完成直接提交事务,释放数据库资源,性能比较好
- 利用全局锁实现读写隔离
- 没有代码侵入,框架自动完成回滚和提交
AT模式的缺点:
- 两阶段之间属于软状态,属于最终一致
- 框架的快照功能会影响性能,但比XA模式要好很多
八、TCC模式原理
TCC模式与AT模式非常相似,每阶段都是独立事务,不同的是TCC通过人工编码来实现数据恢复。需要实现三个方法:
- Try:资源的检测和预留
- Confirm:完成资源操作业务;要求 Try 成功 Confirm 一定要能成功
- Cancel:预留资源释放,可以理解为try的反向操作
8.1 TCC模式举例
一个扣减用户余额的业务。假设账户A原来余额是100,需要余额扣减30元。
- 阶段一( Try ):检查余额是否充足,如果充足则冻结金额增加30元,可用余额扣除30
- 阶段二:假如要提交(Confirm),则冻结金额扣减30
- 阶段二:如果要回滚(Cancel),则冻结金额扣减30,可用余额增加30
8.2 TCC模式优缺点
TCC的优点:
- 一阶段完成直接提交事务,释放数据库资源,性能好
- 相比AT模型,无需生成快照,无需使用全局锁,性能最强
- 不依赖数据库事务,而是依赖补偿操作,可以用于非事务型数据库
TCC的缺点:
- 有代码侵入,需要人为编写try、Confirm和Cancel接口,太麻烦
- 软状态,事务是最终一致
- 需要考虑Confirm和Cancel的失败情况,做好幂等处理
8.3 TCC的空回滚和业务悬挂
空回滚:当某分支事务的try阶段阻塞时,可能导致全局事务超时而触发二阶段的cancel操作。在未执行try操作时先执行了cancel操作,这时cancel不能做回滚。
业务悬挂:对于已经空回滚的业务,如果以后继续执行try,就永远不可能confirm或cancel。
应当阻止执行空回滚后的try操作,避免悬挂,执行try操作需要先判断是否发生过回滚,发生过则结束;执行cancel操作也要先判断try操作是否已经执行过。
ps: TCC模式和AT模式类似,yml文件中不需要修改数据源代理的AT模式,只需要编写实现三个方法即可实现TCC模式。
九、Saga模式
Saga模式是SEATA提供的长事务解决方案。也分为两个阶段:
- 一阶段:直接提交本地事务
- 二阶段:成功则什么都不做;失败则通过编写补偿业务来回滚
9.1 Saga模式优缺点
Saga模式优点
- 事务参与者可以基于事件驱动实现异步调用,吞吐高
- 一阶段直接提交事务,无锁,性能好
- 不用编写TCC中的三个阶段,实现简单
Saga模式缺点
- 软状态持续时间不确定,时效性差
- 没有锁,没有事务隔离,会有脏写
十、四种模式对比
XA | AT | TCC | SAGA | |
---|---|---|---|---|
一致性 | 强一致 | 弱一致 | 弱一致 | 最终一致 |
隔离性 | 完全隔离 | 基于全局锁隔离 | 基于资源预留隔离 | 无隔离 |
代码侵入 | 无 | 无 | 有,要编写三个接口 | 有,要编写状态机和补偿业务 |
性能 | 差 | 好 | 非常好 | 非常好 |
场景 | 对一致性、隔离性有高要求的业务 | 基于关系型数据库的大多数分布式事务场景都可以 | 对性能要求较高的事务。有非关系型数据库要参与的事务。 | 业务流程长、业务流程多参与者包含其它公司或遗留系统服务,无法提供 TCC 模式要求的三个接口 |
->微服务技术栈高级篇--分布式事务--Seata课程视频
高级篇Day2-01-分布式事务理论基础_哔哩哔哩_bilibili
<-
记录每一个学习瞬间
关键词:
播报:分布式事务--Seata
每日速讯:【环球财经】美联储官员发表鹰派言论 美元指数14日显著上涨
华为首次下放卫星通信!nova 11系列上架预约:下周一发布
【焦点热闻】美方以涉俄为由将多家中国企业列入清单实施制裁,商务部回应
【播资讯】史上最大屏!苹果15英寸MacBook Air确认搭载M2芯片:6月发布
医院回应护士上班戴美甲给患者扎针:已让其卸掉!专业人士科普
地产网红称没几千万怎么叫人才引热议:网友称价值观扭曲 谁钱多谁就是人才?
万元买手机很难吗?中美日韩等1月销量TOP 5:iPhone完爆安卓
全球简讯:学系统集成项目管理工程师(中项)系列06a_信息系统安全管理(上)
世界热推荐:国内油价17日料上调 部分地区95号汽油或重返“8元时代”
世界最资讯丨CPU买散片还是盒装 DIY老鸟:怎么选都是错!
当前视讯!沙特俄罗斯等减产后!国内新一轮油价调整将至 或重返8元时代
Java 在线编程工具上线(直接编译运行Java代码)
全球观天下!民声丨合理优化社区规模 提升社会服务质量
环球热门:诚意十足!国产科幻FPS《边境》制作组24小时直播修BUG
环球观速讯丨00后网红马若松遇车祸身亡监控曝光:面包车双实线掉头致追尾
当前速递!性能残血还带风扇 海盗船PCIe 5.0硬盘开卖:性价比竟然很高
世界今日讯!诺基亚一个暗箱操作 给华为喂了口九转大肠
天天快报!小米13 Ultra全曝光 核心配置已无悬念
苹果手机无法下载app什么原因_苹果手机无法下载app是什么原因
天天滚动:4.14训练解题报告
即时:Java + Jpcap实现监控 IP包流量
微头条丨MAUI之Android记录设备号+动态授权
当前焦点!RTX 4070显卡首发驱动531.61发布:4款游戏优化、修复黑屏崩溃
今日观点!南京动物园回应网红猴被欺负困在水中:没有霸凌 会游泳
欧洲探测器启程奔赴木星
【天天新要闻】内部类
当前热讯:c++打卡第五天
ChatGPT如何做投资?
全球今热点:docker_day04:Dockerfile docker私有仓库 dockercompose介绍 dockercompose部署 一件部署路飞项
全球关注:【金融街发布】证监会:取消期货从业资格管理 强化期货从业人员的事中事后监管
世界速讯:20万元买特斯拉?陶琳甩出5张图:中国价格全球最低
天天速看:高通垄断全球基带!中国紫光展锐排第4:2G/3G/4G/5G都很难
环球热议:仙履奇缘3中文版央视网 仙履奇缘3国语版免费
世界速讯:day01-项目介绍与环境搭建
全球快资讯:美光被审查 国产存储芯片崛起的机会来了?
1L体积塞进电源!联想推出小新mini主机:性能超越M2
【时快讯】403秒!中国"人造太阳"又创世界纪录:领先世界5年
环球微动态丨中国巡天太空望远镜明年底发射 将参与近地小行星防御撞击任务
全球讯息:方向导数
高中语文小说情节的作用_高中语文小说的情节题的答题方法 题型
环球快资讯:旺——消费信心加速回归
全球看热讯:可以攒钱了!任天堂Switch 2最快年底发布
实时:14年老牌网站 音悦台官宣回归后向EXO、坤音道歉:欠债一定还
当前快播:《塞尔达传说:王国之泪》实机中黑皮女子是谁:海利亚女神附身塞尔达?
今日精选:亚马逊加入战局:推出大语言模型“泰坦”为客户提供便宜芯片
【全球快播报】藏族女子出嫁带硬核嫁妆走红 价值百万只是一部分:男方根本不用巨额彩礼
今日播报!Nvidia Tensor Core-MMA PTX编程入门
中诚信大湾区信用债券指数系列正式发布
上榜门槛全线上升!2023年一季度粤港澳湾区房企销售榜发布
当前聚焦:通用官宣放弃苹果CarPlay 车企车机自主化势在必行?
等等党措手不及!内存、SSD现货价已开始反弹:三星/美光疯狂减产奏效了
腾讯回应工信部最新要求:微信QQ故障已批评和处罚相关负责人
全球热消息:员工用指纹膜帮同事打卡被开除 不服起诉 法院:不诚信 公司合法解除
天天微动态丨干掉车顶大鼓包!禾赛科技发布舱内激光雷达:高度仅25mm
MySQL学习笔记-索引
如何通过Java程序合并Word文档
观焦点:使用appuploader工具发布证书和描述性文件教程
Vue之 vue-router
记录-Vue.js模板编译过程揭秘:从模板字符串到渲染函数
男子当着7岁女孩面刺56刀杀死前女友:已执行死刑,一审时曾被判死缓
当前讯息:七彩虹五大RTX 4070开卖:水神/火神5699元!神秘新卡加量不加价
号称“不泄密” 微信键盘Windows版上线:不支持Win7
4799元的RTX 4070显卡上市 厂商不急于增产:库存还没完 不想降价
碎片化一地鸡毛!安卓14推送:安卓13用户量仍少的可怜
全球动态:微信功能异常大量用户中招!工信部指导腾讯:重要业务安全稳定
axiom——一款基于云的分布式网络安全扫描工具框架
低代码起势,程序员闷头开发的日子结束了
世界观速讯丨美原油交易策略:油价受阻于200日均线,关注IEA月报
焦点速看:恒生指数14日收涨0.46% 有色金属行业领涨
AITO问界M5智驾版将亮相上海国际车展 余承东:双天花板级体验
世界看热讯:中国药卖给美国人有多难
12元在家看国产科幻大片!《流浪地球2》全网上线:爱优腾会员不免费
当前通讯!7年了!AMD CUDA杀手ROCm终于登陆Windows、支持游戏显卡
俄罗斯发力自主OS系统 无奈碎片化:Linux就有19种
无极县政府网 无极县政府
实时焦点:用 Go 剑指 Offer 31. 栈的压入、弹出序列 (辅助栈)
企业内部培训网站为例,探索云上成本优化
世界新资讯:【财经分析】房企融资边际回暖 结构分化背景下择券仍需审慎
当前通讯!收评:沪指涨0.32%创年内收盘新高 半导体行业掀涨停潮
速读:全国性能最强!腾讯发布高性能算力集群:专为AI大模型训练准备
10碟充氦!希捷首款22TB机械硬盘发布:价格给力
水花消失术再现!全红婵、陈芋汐夺得2023跳水世界杯首金
天天消息!仅重126g!阿里云推出无影云电脑“魔方AS05”:7个全尺寸接口
每日视讯:2450CVIA刷新亮度天花板!当贝X5旗舰投影仪图赏
武磊谈补发2021中国金球奖:荣誉将激励我为中国足球做更多贡献
天天新动态:Huffman实现
即时:《安富莱嵌入式周报》第309期:开源脑机接口套件,三相多电平逆变器,开源电位仪,单片机并行计算,蓝牙市场分析报告,AI密码破解,nRF54H2发布,Z-W
全球微动态丨python 之 session鉴权的处理
【世界播资讯】git中 commit 和 pull 的先后顺序问题会产生多余的merge记录
全球微资讯!#POWERBI 度量值动态格式字符串,利用动态格式,实现百分数智能缩位(powerbi4月重磅更新功能)
高亮度+顶级芯 旗舰更进一步!当贝X5激光投影仪评测:2450CVIA带来震撼视觉体验
焦点速递!免费、不用注册、支持中文!ChatGPT最强竞品爆火:一手实测体验在此
快报:国产FPS《边境》发布之路坎坷:服务器出现紧急BUG
五一火车票明日开售:五一假期连休5天
世界新动态:徕卡味儿十足!小米13 Ultra摄影套装亮相:手机秒变相机
山东省高级人民法院电话簿(山东省高级人民法院电话)
当前报道:全面解析反欺诈(羊毛盾)API,助你识别各类欺诈风险
天天实时:T-SQL基础教程Day2
世界热文:DXO拍照得分全球第一!OPPO Find X6 Pro卖疯 销量同比增长129%