有哪些常见分布式事务解决方案
1、TCC(Try-Confirm-Cancel)
TCC(Try-Confirm-Cancel)是一种基于补偿机制的分布式事务解决方案,它有三个阶段:Try(尝试)、Confirm(确认)、Cancel(取消)。
Try阶段:在Try阶段,参与者可以调用Try阶段的服务,尝试执行本地事务,但是不会对外部系统产生影响;
Confirm阶段:在Confirm阶段,参与者调用Confirm阶段的服务,确认本地事务的执行结果,并将结果反馈给外部系统;
Cancel阶段:在Cancel阶段,参与者调用Cancel阶段的服务,如果Try阶段执行失败,则取消本地事务的执行,并将失败结果反馈给外部系统。
2、XA(eXtended Architecture)
XA是一种基于两阶段提交的分布式事务解决方案,它有两个阶段:Prepare(准备)、Commit(提交)。
Prepare阶段:在Prepare阶段,参与者会准备执行本地事务,但是不会对外部系统产生影响;
Commit阶段:在Commit阶段,参与者会提交本地事务的执行结果,并将结果反馈给外部系统。
3、2PC(Two-Phase Commit)
2PC(Two-Phase Commit)也是一种基于两阶段提交的分布式事务解决方案,它有两个阶段:Prepare(准备)、Commit(提交)。
Prepare阶段:在Prepare阶段,参与者会准备执行本地事务,但是不会对外部系统产生影响;
Commit阶段:在Commit阶段,参与者会提交本地事务的执行结果,并将结果反馈给外部系统。
4、Saga(十二恶八)
Saga(十二恶八)是一种基于补偿机制的分布式事务解决方案,它有多个阶段:Try(尝试)、Compensate(补偿)。
Try阶段:在Try阶段,参与者可以调用Try阶段的服务,尝试执行本地事务,但是不会对外部系统产生影响;
Compensate阶段:在Compensate阶段,参与者调用Compensate阶段的服务,如果Try阶段执行失败,则取消本地事务的执行,并将失败结果反馈给外部系统。
猜您想看
-
ES的基本概念是什么
一、什么是El...
2023年05月26日 -
怎么解决ORACLE在修改主键时出现ORA-00955的问题
问题背景:在修...
2023年07月20日 -
python奇怪的xpath bug举例分析
Python ...
2023年05月26日 -
shell中常用的串口调试命令怎么用
串口调试命令概...
2023年07月22日 -
为什么我的苹果手机无法链接支付宝?
如何解决苹果手...
2023年04月27日 -
区块链溯源应用场景搭建的解决方案是什么
一、区块链溯源...
2023年05月25日