分布式事务TCC补偿机制

文章目录

    • 概述
    • 工作流程
    • 优缺点
      • 优点:
      • 缺点:
    • 总结
    • Java 示例代码

概述

TCC(Try-Confirm-Cancel)补偿机制是一种事务处理模式,用于确保分布式系统中的操作成功完成或在失败时进行补偿。TCC将一个事务拆分为三个阶段,即Try、Confirm和Cancel阶段。在Try阶段,业务系统尝试执行事务并锁定所需资源。如果Try阶段成功,业务系统将进入Confirm阶段并提交事务。如果Try阶段失败或出现其他异常情况,业务系统将回滚事务并释放所有锁定的资源。
TCC 采用了补偿机制,其核心思想:针对每个操作,都要注册一个与其对应确认和补偿(撤销)操作。
TCC是一种尝试性执行,若所有参与结点都有事务执行的条件,那么直接执行事务。否则Cancel回滚操作。
对业务的操作入侵比较大,耦合性高,对于Try和Cancel可能需要重试
需要业务系统保证操作的幂等性,从业务角度的实现方案,因此可以跨数据库、跨业务系统。
TCC 方案让应用可以自定义数据库操作粒度,降低了锁冲突,可以提升性能。
但应用侵入性强,try、confirm、cancel 三个阶段都需要业务逻辑实现。

工作流程

TCC(Try-Confirm-Cancel)是一种分布式事务解决方案,它通过明确的三个阶段来保证分布式事务的一致性。TCC补偿机制是TCC模式中用于处理事务失败时的补偿操作。
TCC模式的三个阶段:
1.Try(尝试)阶段:在该阶段,业务系统会尝试预留资源并执行业务操作,但此时并未对资源进行真正的修改。如果所有的参与者都能够成功预留资源,那么就可以进入下一个阶段。如果任何一个参与者预留资源失败,那么就需要进行补偿操作。
2.Confirm(确认)阶段:在该阶段,业务系统会对之前预留的资源进行真正的修改,并确认事务的完成。如果所有的参与者都成功完成了资源的修改,那么事务就可以顺利提交。如果任何一个参与者在这个阶段失败,那么就需要进行补偿操作。
3.Cancel(取消)阶段:在该阶段,业务系统会对之前预留的资源进行释放或者回滚操作,并且将之前的操作进行撤销。如果所有的参与者都成功释放了资源并完成了撤销操作,那么事务就可以终止。如果任何一个参与者在这个阶段失败,那么同样需要进行补偿操作。
TCC补偿机制的详细过程如下:
1.当某个参与者在Try阶段失败时,需要执行相应的补偿操作。补偿操作的目的是撤销或者回滚之前的操作,以保证数据的一致性。
2.补偿操作应该是幂等的,即可以多次执行而不会产生额外的影响。这样在补偿过程中出现的网络故障或者其他问题时,可以重试补偿操作而不会导致数据不一致。
3.补偿操作通常是和Confirm或Cancel阶段相对应的,具体选择是根据业务需求和场景来确定的。
4.补偿操作应该尽可能地快速执行,以便尽早恢复到一致的状态。
5. 可以通过定时任务或者人工干预来触发和执行补偿操作。
在这里插入图片描述

优缺点

优点:

1.TCC补偿机制的优点在于它提供了更高的可靠性和一致性。通过在事务执行过程中引入确认和取消机制,TCC确保了即使在出现错误或异常情况下,系统状态仍然保持一致。此外,TCC还提供了更好的资源管理和锁定控制,有助于提高系统的性能和效率。
2.可以灵活控制事务的边界:TCC模式通过明确的三个阶段来控制分布式事务的边界,可以灵活地控制事务的粒度和范围,减少事务的锁竞争和冲突。
3.可以提高系统的并发性能:TCC模式可以将事务的过程拆分成多个阶段,每个阶段可以并发执行,从而提高系统的并发性能和吞吐量。
4.可以降低分布式事务的复杂度:TCC模式可以将分布式事务的复杂度降低到可控的范围内,便于管理和维护。
5.可以保证数据的一致性:TCC补偿机制可以保证在分布式事务失败时,可以通过补偿操作将数据恢复到一致的状态,确保数据的正确性和完整性。

缺点:

1.实现复杂度较高:TCC模式相对于其他分布式事务解决方案,实现复杂度较高,需要对业务逻辑进行深入的理解和设计。
2.可能存在性能问题:TCC模式需要进行多次网络通信和状态转换,可能会对系统的性能产生一定的影响,尤其是在高并发场景下。
3.事务边界难以确定:TCC模式需要明确事务的边界和阶段,但在某些场景下,事务的边界难以确定,容易出现事务处理失败的情况。
4.补偿操作复杂性高:TCC补偿机制需要对每个参与者进行相应的补偿操作,补偿操作的复杂性取决于业务场景和实现方式,可能会带来额外的开销和复杂性。
5.然而,TCC也有其局限性。它需要更多的系统资源和处理时间,因为每个事务都需要经过Try、Confirm和Cancel三个阶段。此外,它也需要更复杂的事务管理逻辑和编程模型,增加了开发人员的工作量和难度。
综上所述,TCC补偿机制作为TCC模式中保证分布式事务一致性的关键机制之一,具有其优点和缺点。在选择分布式事务解决方案时,需要根据具体业务需求和场景来选择最合适的方案。

总结

总的来说,TCC补偿机制是一种用于确保分布式系统中事务一致性和可靠性的处理模式。它通过引入Try、Confirm和Cancel三个阶段来提供更好的资源管理和锁定控制,但也需要更多的系统资源和处理时间。在实施这种机制时,需要权衡其优缺点,并确保它适合特定应用的需求。
需要注意的是,TCC补偿机制虽然可以处理分布式事务的一致性,但也带来了一些额外的开销和复杂性。在使用TCC模式时,需要仔细考虑业务场景和需求,并确保补偿操作的正确性和可靠性。此外,还可以通过日志记录、消息队列等技术手段来增加系统的可靠性和容错性。

Java 示例代码

以下是一个简单的 Java 示例代码,演示了如何使用 TCC 模式和补偿机制来处理分布式事务:

public interface OrderService {@Compensable(confirmMethod = "confirmPlaceOrder", cancelMethod = "cancelPlaceOrder")void tryPlaceOrder(Order order);void confirmPlaceOrder(Order order);void cancelPlaceOrder(Order order);
}public class OrderServiceImpl implements OrderService {@Autowiredprivate InventoryService inventoryService;@Autowiredprivate PaymentService paymentService;@Overridepublic void tryPlaceOrder(Order order) {// 尝试预留资源并执行业务操作try {// 预留库存资源inventoryService.reserveInventory(order);// 预留支付资源paymentService.reservePayment(order);} catch (Exception e) {// 预留资源失败,抛出异常进行补偿操作throw new CompensableTransactionException(e);}}@Overridepublic void confirmPlaceOrder(Order order) {// 确认事务完成,对之前预留的资源进行真正的修改inventoryService.updateInventory(order);paymentService.confirmPayment(order);}@Overridepublic void cancelPlaceOrder(Order order) {// 取消事务,并对之前预留的资源进行释放或者回滚操作inventoryService.releaseInventory(order);paymentService.rollbackPayment(order);}
}public interface InventoryService {void reserveInventory(Order order);void updateInventory(Order order);void releaseInventory(Order order);
}public interface PaymentService {void reservePayment(Order order);void confirmPayment(Order order);void rollbackPayment(Order order);
}

在上面的示例中,OrderService 接口定义了 tryPlaceOrder、confirmPlaceOrder 和 cancelPlaceOrder 方法,并使用 @Compensable 注解标记 tryPlaceOrder 方法,指定了 confirmMethod 和 cancelMethod 的名称。OrderServiceImpl 类实现了 OrderService 接口,通过 Autowired 注解注入了 InventoryService 和 PaymentService。在 tryPlaceOrder 方法中,调用了 inventoryService 和 paymentService 提供的方法进行资源的预留。如果预留失败,则抛出 CompensableTransactionException 异常,触发补偿操作。在 confirmPlaceOrder 和 cancelPlaceOrder 方法中,分别对之前预留的资源进行真正的修改和释放/回滚操作。InventoryService 和 PaymentService 接口分别定义了预留、确认和取消操作的方法,具体实现根据业务需求进行编写。需要注意的是,以上示例代码为简化的示例,实际应用中还需要考虑事务的管理、幂等性处理、异常处理等方面的内容。具体实现要根据业务需求和框架选择进行适当的调整和扩展。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/287045.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter之导url_launcher包提示 A dependency may only have one source.

1、问题 flutter项目在pubspec.yaml导入url_launcher包,然后点击Pub get错误提示如下 F:\flutter_sdk\flutter\bin\flutter.bat --no-color pub get Running "flutter pub get" in flutter_1... Error on line 25, column 5 of …

这是我第一次使用代码创建出一个窗口【python 游戏实战 01】

前言 本系列文章将会以通俗易懂的对话方式进行教学,对话中将涵盖了新手在学习中的一般问题。此系列将会持续更新,包括别的语言以及实战都将使用对话的方式进行教学,基础编程语言教学适用于零基础小白,之后实战课程也将会逐步更新…

如何html中添加动态图片,把动态图片添加到视频画面中 视频添加自定义动态图片 视频加动态logo...

我前面也编写过关于视频添加动态图片的教程。前面所说的给是视频添加的动态图片是软件中自带的素材,虽然软件中带的动态图片种类繁多,但是不外乎有些时候软件中并没有我们要用的动态图片,这个时候我们就需要重外部添加啦,好多的软…

ASP.NET Core 集成AAD认证在Docker中运行时要注意的一个问题

最近我在准备一个分享,就是基于.NET 6.0的云原生开发Microsoft 365应用,这个看起来很高大上的东东,其实我理解主要就是能把应用容器化,便于与环境无关地进行分发和部署。如果理解有误,请大家纠正我。下面是其中的一个例…

ArcGIS中合并(merge)、联合(union)、追加(append)、融合(dissolve)的用法区别与联系

ArcGIS中,针对矢量数据拼接,有多个工具:合并(merge)、联合(union)、追加(append)、融合(dissolve)等,本文以甘肃省1:100万县级数据详细讲解以上各个工具的用法、区别和注意事项。 有关合并(merge)、联合(union)、追加(append)、融合(dissolve)等基础操作内…

Singleton

问题:编写一个Singleton类 简单的方式 1 package cn.changb.singleton;2 3 /**4 * 简单的方式:弊端是在并发执行时,14行处可能存在多个实例5 */6 public class SingletonDemo1 {7 private static SingletonDemo1 INSTANCE;8 9 private Singlet…

C++ 语法都不会怎么写代码? 03

作者简介 作者名:1_bit 简介:CSDN博客专家,2020年博客之星TOP5,蓝桥签约作者。15-16年曾在网上直播,带领一批程序小白走上程序员之路。欢迎各位小白加我咨询我相关信息,迷茫的你会找到答案。系列教程将会…

自定义dialog弹窗html,自定义H5页面dialog弹窗

弹窗一:样式如下:HTML代码://弹出窗通知取消确认//遮罩层$(.dialog .content).text(text);$(.dialog, .mark).removeClass(hide);}tipDialog("1111");$(".sure").click(function(){var type $(this).attr(type);if(typeb…

聊一聊容器暂停退出

1背景介绍 最近在写 docker 相关教程,过程中发现容器暂停退出竟然有 docker kill、docker stop 和 docker pause 三种方式,今天就来分析下三者间的区别。2辅助指令 docker top - 查看容器进程docker event - 查看容器相关事件docker stats -…

初学者必看的文章:在VM12中安装 RedHat RHEL7.2  系统的详细步骤:看我如何操纵RHEL系统...

一、开始安装 1)新建虚拟机 RHEL7.2 2)成功引导系统--开机出现此画面 Install Red Hat EnterpriseLinux 7.2 安装RHLE7.2 操作系统 Test this edia & install RedHat Enterpris…

Flutter之点击按钮打开百度链接

1 需求 点击按钮,打开百度链接 2 代码实现 import package:flutter/material.dart; import package:url_launcher/url_launcher.dart;void main() {runApp(MyApp1()); }class MyApp1 extends StatelessWidget {overrideWidget build(BuildContext context) {return…

因为我的名字特殊大家都是用异样的眼光在看着我 04

作者简介 作者名:1_bit 简介:CSDN博客专家,2020年博客之星TOP5,蓝桥签约作者。15-16年曾在网上直播,带领一批程序小白走上程序员之路。欢迎各位小白加我咨询我相关信息,迷茫的你会找到答案。系列教程将会…

undefined reference to 问题解决方法

最近在Linux下编程发现一个诡异的现象,就是在链接一个静态库的时候总是报错,类似下面这样的错误: (.text0x13): undefined reference to func 关于undefined reference这样的问题,大家其实经常会遇到,在此&#xff0c…

WPF 实现扇形统计图

扇形统计图原文作者:ArcherSong博客地址:https://www.cnblogs.com/ganbei/绘制一个扇形原理也是基于Canvas进行绘制;ArcSegment[1]绘制弧形;绘制指示线;绘制文本;鼠标移入动画;显示详情Popup;源码Github[2]…

Flutter之测试Http和HttpClient

1 测试Http和HttpClient 导入包:在pubspec.yaml里面导入 http: ^0.12.2 main.dart里面导入 import package:http/http.dart as http; import dart:convert; import dart:io; 2 代码实现 import package:flutter/material.dart; import package:url_launcher/url_lau…

基于zookeeper的solrCloud集群搭建

1.安装及搭建相关环境 1.1环境准备 centos7,jdk1.8,tomcat8,zookeeper3.4.X,solr4.10.X 链接: https://pan.baidu.com/s/1i47IuKd 密码: emqt 2.zookeeper集群搭建 2.1复制zookeeper [rootMiWiFi-R3-srv ~]# mkdir /usr/local/solr-cloud [rootMiWiFi-R3-srv ~]# cp -r zookee…

【小白必懂】C语言求完全数

注意:学生党如果存在付费问题可以加我好友,我可以开单篇短时间的免费哟~ 私聊我就好~ 情景再现 👸小媛:小C,你知道什么是完全数吗? 🐰小C:知道呀,难道是今天老师又出题…

台式计算机硬件输入设备,台式电脑硬件配置有哪些

台式电脑硬件配置你知道有哪些?电脑的配置一般是指电脑的硬件配件的高档程度、性价比等,电脑的性能好坏主要决定于以下主要硬件配置。一起来看看台式电脑硬件配置有哪些,欢迎查阅!组装台式电脑配置1、实用性机型建议:首选1:intel…

Android WebView和JavaScript交互

JavaScript在现在的网页设计中用得很多,Android 的WebView可以载入网页,WebView也设计了与JavaScript通信的桥梁。这篇主要介绍一下WebViewk控件如何和JavaScript进行交互。 WebView: WebView和网页相关的主要有一下几个方法:  setWebViewCl…

Microsoft Dev Box 带来全新云上开发体验

在 5 月 24 日, 微软的产品经理 Anthony Cangialosi 在 Azure 社区发布了一篇博客(Introducing Microsoft Dev Box), 宣布推出 Microsoft Dev Box !这是一种新的云服务,托管在 Microsoft Azure 中,提供了一个开箱即用的开发工作站&#xff0c…