分布式事务-TCC

2024-05-30 07:52
文章标签 分布式 事务 tcc

本文主要是介绍分布式事务-TCC,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分布式事务TCC是一种补偿式的分布式事务解决方案,旨在保证在分布式系统中,跨多个服务或资源的事务能够保持一致性和可靠性。

一、TCC概述

TCC,全称Try-Confirm-Cancel,是一种用于处理分布式事务的协议。其核心思想是通过在业务逻辑中嵌入三个阶段(Try、Confirm、Cancel)的操作,来确保在分布式事务中,各个参与者能够协同工作,实现事务的原子性。TCC协议本身不保证事务隔离性,一阶段执行完成就提交本地事务,需要业务模型实现时解决事务隔离性问题。

二、TCC运行流程

  1. Try阶段

    • 业务逻辑会预留资源,并检查所有的前提条件是否满足。

    • 如果检查通过,则执行业务逻辑,进入Confirm阶段;否则,回滚预留的资源,进入Cancel阶段。

  2. Confirm阶段

    • 在这个阶段,业务逻辑会确认执行结果。

    • 如果确认通过,则提交所有的操作,完成事务;否则,回滚所有的操作,进入Cancel阶段。

  3. Cancel阶段

    • 如果在Try或Confirm阶段出现错误或异常,业务逻辑会撤销之前执行的操作,并释放之前预留的资源。

三、TCC实现流程

1. 定义TCC接口

首先,需要定义TCC操作的接口,通常包括三个方法:tryconfirmcancel

  • try 方法:尝试执行业务操作,并预留必要的资源。如果成功,则返回一个全局唯一的事务ID(通常称为XID)和表示操作是否成功的结果。

  • confirm 方法:确认try阶段成功提交的操作。它应该是一个幂等操作,即使多次调用也应该产生相同的结果。

  • cancel 方法:取消try阶段预留的资源,并回滚可能的业务操作。同样,它也应该是一个幂等操作。

2. 实现TCC业务逻辑

业务代码中,需要实现上述三个方法的具体逻辑。

  • try 方法中,需要执行实际的业务操作,并预留资源。这可能包括数据库记录的锁定、外部服务的调用等。如果所有操作都成功,则返回成功结果和XID;否则,返回失败结果并可能触发cancel操作。

  • confirm 方法中,需要根据XID确认并提交try阶段的操作。。

  • cancel 方法中,需要根据XID取消并回滚try阶段预留的资源。

3. 管理事务状态

需要实现事务协调器,可以通过将事务状态存储在数据库、缓存或分布式系统中来实现。事务状态可以包括:TRYING(正在尝试)、CONFIRMED(已确认)、CANCELED(已取消)等。

4. 调用TCC接口

业务流程中,当需要执行分布式事务时,需要按照以下步骤调用TCC接口:

  1. 调用try方法执行业务操作并预留资源。

  2. 根据try方法的返回结果决定是否调用confirmcancel方法。

  3. 如果try方法成功,则调用confirm方法提交事务;否则,调用cancel方法回滚事务。

5. 异常处理和重试

在分布式系统中,网络分区、服务故障等异常情况是不可避免的。因此,需要实现异常处理和重试机制来确保TCC事务的可靠性。

  • 对于try方法,如果发生异常,可以根据具体情况选择是否重试或调用cancel方法。

  • 对于confirmcancel方法,由于它们是幂等操作,因此可以安全地重试,直到它们成功为止。

6.注意事项
  • 幂等性confirmcancel方法必须是幂等的,以确保多次调用不会产生副作用。

  • 事务隔离性:在try阶段,需要确保对资源的访问是隔离的,以避免并发冲突,即通过资源预留的方式解决事务隔离性问题。

  • 超时处理:为tryconfirmcancel操作设置合理的超时时间,并在超时时采取相应的措施(如重试、回滚等)。

  • 错误处理:为可能出现的各种错误和异常情况设计合理的错误处理策略。

四、TCC的优缺点

优点

  1. 灵活性:TCC允许在业务逻辑中自定义补偿操作,可以根据具体业务场景进行灵活配置。

  2. 支持分布式事务:TCC可以支持跨多个服务或资源的分布式事务,保证事务的一致性和可靠性。

  3. 减少阻塞时间:Try阶段可以预留资源,从而减少了阻塞时间,提高了并发能力,从而提升性能。

缺点

  1. 应用侵入性强:TCC需要在业务逻辑中嵌入Try-Confirm-Cancel三个阶段的逻辑,对于现有系统的改造成本较高。

  2. 开发难度大:代码开发量较大,需要保证confirm和cancel接口的幂等性,增加了开发的复杂度。

五、总结

TCC作为一种补偿式的分布式事务解决方案,在分布式系统中具有重要的作用。它通过在业务逻辑中嵌入Try-Confirm-Cancel三个阶段的逻辑,来保证分布式事务的一致性和可靠性。然而,TCC也存在一些缺点,如应用侵入性强、开发难度大等。因此,在选择分布式事务解决方案时,需要根据具体业务场景和需求进行权衡和选择。

这篇关于分布式事务-TCC的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1015941

相关文章

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因

laravel框架实现redis分布式集群原理

在app/config/database.php中配置如下: 'redis' => array('cluster' => true,'default' => array('host' => '172.21.107.247','port' => 6379,),'redis1' => array('host' => '172.21.107.248','port' => 6379,),) 其中cl

基于MySQL实现的分布式锁

概述 在单机时代,虽然不需要分布式锁,但也面临过类似的问题,只不过在单机的情况下,如果有多个线程要同时访问某个共享资源的时候,我们可以采用线程间加锁的机制,即当某个线程获取到这个资源后,就立即对这个资源进行加锁,当使用完资源之后,再解锁,其它线程就可以接着使用了。例如,在JAVA中,甚至专门提供了一些处理锁机制的一些API(synchronize/Lock等)。 但是到了分布式系统的时代,这种

Kafka 分布式消息系统详细介绍

Kafka 分布式消息系统 一、Kafka 概述1.1 Kafka 定义1.2 Kafka 设计目标1.3 Kafka 特点 二、Kafka 架构设计2.1 基本架构2.2 Topic 和 Partition2.3 消费者和消费者组2.4 Replica 副本 三、Kafka 分布式集群搭建3.1 下载解压3.1.1 上传解压 3.2 修改 Kafka 配置文件3.2.1 修改zookeep

spring事务属性的xml格式配置

实际是使用代理做的事务优化 <!--配置事务的属性--><tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <!--匹配所有以add开头的方法--><tx:method name="add*" propagation="REQUIRED" /> <tx:metho

Spring Cloud整合Seata实现分布式事务

文章目录 1.Seata1.1 官网1.2 下载1.3 通过安装包运行seata1.3.1 解压seata-server-1.3.0.zip1.3.2 修改 conf/file.conf 配置文件1.3.3 修改conf/registry.conf配置文件1.3.4 添加seata配置信息到nacos1.3.5 配置seata服务端数据库表结构1.3.6 启动seata 2.Spring

ELK+Spring Cloud搭建分布式日志中心

ELK+Spring Cloud搭建分布式日志中心 1.ELK简介2.资源包下载3.Elasticsearch安装3.1 解压Elasticsearch3.2 修改Elasticsearch的配置文件3.3 修改系统配置3.4 启动Elasticsearch 4.ElasticSearch-head插件安装5.Logstash安装6.Kibana安装7.SpringCloud集成logsta