分布式事务TCC补偿机制

news2024/9/30 23:39:11

文章目录

    • 概述
    • 工作流程
    • 优缺点
      • 优点:
      • 缺点:
    • 总结
    • 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 {
    @Autowired
    private InventoryService inventoryService;

    @Autowired
    private PaymentService paymentService;

    @Override
    public void tryPlaceOrder(Order order) {
        // 尝试预留资源并执行业务操作
        try {
            // 预留库存资源
            inventoryService.reserveInventory(order);
            // 预留支付资源
            paymentService.reservePayment(order);
        } catch (Exception e) {
            // 预留资源失败,抛出异常进行补偿操作
            throw new CompensableTransactionException(e);
        }
    }

    @Override
    public void confirmPlaceOrder(Order order) {
        // 确认事务完成,对之前预留的资源进行真正的修改
        inventoryService.updateInventory(order);
        paymentService.confirmPayment(order);
    }

    @Override
    public 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.coloradmin.cn/o/1333038.html

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

相关文章

零基础快速上手HarmonyOS ArkTS开发2---ArkTS开发实践

ArkTS开发实践: 接着上一次零基础快速上手HarmonyOS ArkTS开发1---运行Hello World、ArkTS开发语言介绍继续, 在上一次对于ArkTS的基础知识进行了学习,依照官方的课程计划,还有两个具体的小案例需要来实践实践: 实践出…

基于Go语言的HTTP路由设计与实现

在Go语言的世界里,HTTP路由是一种将HTTP请求映射到相应处理函数的技术。通过路由,我们可以确定当用户发送一个HTTP请求时,应该调用哪个函数来处理该请求。在这个过程中,我们可以使用多种方法来实现路由设计,下面我将以…

leetcode——背包问题汇总

本章来汇总一下leetcode中做过的背包问题,包括0-1背包和完全背包。 背包问题的通常形式为:有N件物品和一个最多能背重量为W 的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。求解将哪些物品装入背包里物品价值总和最大。0-1背包和…

040、全卷积

之——FCN 目录 之——FCN 杂谈 正文 1.FCN 2.实现 杂谈 FCN(Fully Convolutional Network)是一种深度学习网络架构,专门设计用于语义分割任务。传统的深度学习网络如卷积神经网络(CNN)在处理图像时通常用于分类…

学生管理系统 数据库版结果 查询student表中所有学生信息

1.创建school_java数据库 CREATE DATABASE schooljava; USE schooljava; CREATE TABLE student ( id INT(11), name VARCHAR(25), tel INT(11), sex VARCHAR(6) ); DESC student; java代码 package Mysql; import java.sql.Connection; import java.sql.DriverManager; imp…

16-高并发-队列术

队列,在数据结构中是一种线性表,从一端插入数据,然后从另一端删除数据。 在我们的系统中,不是所有的处理都必须实时处理,不是所有的请求都必须实时反馈结果给用户,不是所有的请求都必须100%一次性处理成功…

ubuntu下docker安装,配置python运行环境

参考自: 1.最详细ubuntu安装docker教程 2.使用docker搭建python环境 首先假设已经安装了docker,卸载原来的docker 在命令行中运行: sudo apt-get updatesudo apt-get remove docker docker-engine docker.io containerd runc 安装docker依赖 apt-get…

041、基于CNN的样式迁移

之——基于CNN的滤镜 目录 之——基于CNN的滤镜 杂谈 正文 1.基于CNN的样式迁移 2.实现 杂谈 通过CNN的特征提取,可以实现将一个图片的样式模式特征迁移到另一张图像上。 正文 1.基于CNN的样式迁移 就是在某些层的输出上用其他的图片进行监督。 2.实现 一般来…

算法基础之完全背包问题

完全背包问题 核心思想:集合表示: f[i][j]表示前i种物品 总容量不超过j的最大价值 求f[i][j]时 分为选0、1、2……n个第i种物品 n种情况 每种情况为 f[i][j-kv] (取k个第i种物品) 即f[i][j] max(f[i-1][j] , f[i-1][j-v]w,f[i-1][j-2v]2w….f[i-1][j-k…

探索应用程序的指路明灯:Route 和 Router 入门指南(上)

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云…

[MySQL binlog实战] 增量同步与数据搜索~从入门到精通

学习基础知识,并落实到实际场景(增量同步数据搜索) 对基础知识不感兴趣的,可以直接跳到应用场景 文章目录 binlog是什么简介产生方式文件格式statementrowmixed 怎么办开启 binlog查看 binlog其他查看相关命令运维查看 binlog设置…

ARM学习(24)Can的高阶认识和错误处理

笔者来聊一下CAN协议帧的认识和错误处理。 1、CAN协议帧认识 CAN 差分信号,是经过CAN收发器转成差分信号的,CAN RX和TX是逻辑电平。CAN的基础知识,可参考笔者这边文章:ARM学习(21)STM32 外设Can的认识与驱…

数据结构 | 查漏补缺

目录 数据的基本单位 冒泡排序 DFS和BFS中文 Prim 比较 中序线索二叉树 顺序栈 链栈 时间复杂度 循环队列 求第K个结点的值 数据的基本单位 数据元素 循环队列sq中,用数组elem[0‥25]存放数据元素,设当前sq->front为20,sq-&g…

谷歌推大语言模型VideoPoet:文本图片皆可生成视频和音频

Google Research最近发布了一款名为VideoPoet的大型语言模型(LLM),旨在解决当前视频生成领域的挑战。该领域近年来涌现出许多视频生成模型,但在生成连贯的大运动时仍存在瓶颈。现有领先模型要么生成较小的运动,要么在生…

Vue 封装echarts柱状图(Bar)组件

目的&#xff1a;减少重复代码&#xff0c;便于维护 显示效果 组件代码 <template><div class"ldw-data-content-box"><div class"ldw-chilren-box"><div class"title" v-if"title">{{ title }}</div>…

软件测试5未来大发展路线,测试工程师发展偏向

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、软件测试的五大…

Python之classmethod和staticmethod的区别

python中3种方式定义类方法&#xff0c;常规方式、classmethod修饰方式、staticmethod修饰方式。 class A(object):def foo(self, x):print(调用foo函数 (%s, %s)%(self, x))print(self:, self)classmethoddef class_foo(cls, x):print(调用class_foo函数 (%s, %s) % (cls, x))…

【算法提升—力扣每日一刷】五日总结【12/18--12/22】

文章目录 2023/12/18LeetCode每日一刷&#xff1a;[20. 有效的括号](https://leetcode.cn/problems/valid-parentheses/) 2023/12/19LeetCode每日一刷&#xff1a;[150. 逆波兰表达式求值&#xff08;后缀表达式运算&#xff09;](https://leetcode.cn/problems/evaluate-rever…

博主自制丨免费下载丨免费使用丨仅用于测试

链接&#xff1a;点我立即下载 提取码&#xff1a;0j6h

CentOS 7 设置网络

CentOS 7 设置网络 正常情况 ①登陆进去之后使用下面的命令修改文件 echo ONBOOTyes >> /etc/sysconfig/network-scripts/ifcfg-ens33②如果是虚拟机重启后使用如下命令进行查看IP地址 ip addr注&#xff1a;到这里如果显示有两部分&#xff0c;则代表网络设置成功&a…