当前位置: 首页 > news >正文

【TCC分布式事务】

TCC实现指令原子性的原理

TCC(Try-Confirm-Cancel)通过三阶段操作实现业务层面分布式事务的原子性,其核心在于资源预留和状态管理的设计:

Try阶段(预留)

  • 对涉及的所有业务操作预先检查并预留资源,例如锁定库存、冻结账户余额、生成临时订单等。此阶段不直接提交最终操作,而是确保后续Confirm或Cancel可执行。
  • 每个子服务的Try操作独立执行,若全部成功则进入Confirm阶段;任一失败则触发Cancel阶段。

Confirm阶段(确认)

  • 基于Try阶段预留的资源,执行最终业务操作(如扣减库存、实际扣款)。此时因资源已预留,操作必然成功。
  • 需设计幂等性接口,防止网络重试导致重复提交。

Cancel阶段(撤销)

  • 当Try阶段部分失败时,撤销已预留的资源(如释放库存、解冻金额)。同样需保证幂等性。

对比二阶段提交(2PC)

  • 数据层:2PC在数据库层面通过Prepare/Commit实现,依赖数据库事务。
  • 业务层:TCC将事务控制上移到业务代码,通过预留+确认/撤销的抽象模式,灵活适配异构系统。

实际应用关键点

  1. 幂等性设计
    Confirm/Cancel可能因网络问题重试,需通过唯一事务ID或状态标记避免重复执行。

  2. 资源预留方式

    • 数据库操作:通过状态字段(如status=TRY_RESERVED)标记预留状态,Confirm时更新为CONFIRMED
    • 外部服务调用:如机票预订场景,航空公司接口需提供预留、确认、撤销三个独立接口。
  3. 超时与悬挂问题
    需引入事务协调器记录状态,避免Try成功但因网络丢失导致长期未Confirm/Cancel的资源滞留。

开源实现参考

  • Seata:支持TCC模式,提供全局事务协调框架。
  • Hmily:轻量级TCC事务框架,适用于微服务场景。

示例场景解答(订票系统)

  1. Try阶段

    • 调用深圳航空接口预留深圳→上海机票(锁定座位,生成临时订单)。
    • 调用上海航空接口预留上海→北京机票。
  2. Confirm阶段

    • 两段机票均预留成功时,分别调用确认接口完成实际出票。
  3. Cancel阶段

    • 若深圳航空预留失败,则调用上海航空的撤销接口释放预留座位。

通过这种设计,无论涉及多少服务,只要所有Try成功则最终确认,否则全部撤销,从而保证原子性。

http://www.cnnetsun.cn/news/53979.html

相关文章:

  • CAJ文档解密终极指南:3步突破时间限制
  • TranslucentTB中文界面设置终极指南:三步搞定任务栏透明工具语言切换
  • 5分钟精通Windows更新通道自由切换:OfflineInsiderEnroll深度解析
  • 抖音无水印视频下载器:5分钟掌握高清保存技巧
  • 如何快速下载B站4K高清视频:完整技术指南
  • ViGEmBus虚拟控制器技术架构与实战应用
  • Elsevier Tracker终极指南:3步实现论文审稿状态自动化追踪
  • 如何快速掌握GeoJSON.io:在线地图编辑的终极解决方案
  • 智能告警降噪的测试实践
  • pythonstudy Day35
  • 测试成熟度的AI评估框架
  • Qt进程启动方法对比:start、startDetached、execute
  • Claude和Cursor之间的切换
  • AI剪辑革命:5步生成电影级预告片
  • Windows 7系统完美运行Umi-OCR:终极兼容指南
  • 【MAT1001】托马斯微积分期末复习提纲详解
  • Switch系统优化终极指南:从零基础到精通大气层系统
  • JVM G1 和 CMS 详解与对比
  • 实战解析:2PC与Saga分布式事务的完全避坑指南
  • Lumafly模组管理器:重构空洞骑士模组生态的专业解决方案
  • 12.14 - 搜索旋转排序数组 判断两个结构体是否相等
  • WaveTools鸣潮120帧解锁与游戏性能优化全攻略
  • 三步学会百度网盘极速下载:告别龟速的终极方案
  • 5大实用技巧:用Calibre-Douban插件智能管理电子书元数据
  • 飞书文档批量导出终极指南:一键解决文档迁移难题
  • Source Han Serif思源宋体:免费开源中文字体专业应用指南
  • DOM Element:深入理解与操作
  • 深度解析 Flutter 路由管理:从原生路由到 AutoRoute 的优雅升级与性能优化
  • Turnitin系统查英文AI率多少为正常?报告显示星号*%怎么办?
  • 暖通净化空调恒温恒湿项目:PLC 与触摸屏上位机程序探秘