news 2026/1/25 12:49:04

【TCC分布式事务】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【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成功则最终确认,否则全部撤销,从而保证原子性。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/19 6:40:16

如何快速掌握多视频同步播放:GridPlayer终极操作指南

如何快速掌握多视频同步播放:GridPlayer终极操作指南 【免费下载链接】gridplayer Play videos side-by-side 项目地址: https://gitcode.com/gh_mirrors/gr/gridplayer 在视频剪辑、教育培训和监控管理等专业场景中,同步播放多个视频源是提升工作…

作者头像 李华
网站建设 2026/1/20 15:16:39

iStore插件中心终极指南:OpenWRT新手轻松安装与管理插件

iStore是OpenWRT系统的标准软件中心,采用纯脚本实现,仅依赖OpenWRT标准组件,为新手用户提供像手机应用商店一样简单直观的插件安装体验。无论是刚接触OpenWRT的新手还是资深用户,iStore都能帮你快速找到并安装所需插件&#xff0c…

作者头像 李华
网站建设 2026/1/20 7:19:59

小米运动智能步数生成与多平台同步方案

小米运动智能步数生成与多平台同步方案 【免费下载链接】mimotion 小米运动刷步数(微信支付宝)支持邮箱登录 项目地址: https://gitcode.com/gh_mirrors/mimo/mimotion 还在为每天的运动步数不达标而烦恼?想让小米运动数据自动同步到微…

作者头像 李华
网站建设 2026/1/8 7:32:25

自愈测试环境的AI实现

随着敏捷开发和DevOps的普及,测试环境需满足高频变更与快速反馈的需求。然而,手动维护环境成本高昂,且故障响应延迟可能拖累整个交付流程。自愈测试环境通过AI实时监控、诊断和修复问题,实现“零接触”运维,成为测试效…

作者头像 李华
网站建设 2026/1/9 3:43:50

后量子密码测试方案:构建面向未来的安全验证体系

引言:后量子密码测试的紧迫性与挑战 随着量子计算技术的快速发展,传统公钥密码体系(如RSA、ECC)面临着被量子算法破解的潜在风险。根据全球技术演进轨迹预测,到2030年量子计算机可能具备破解现有加密体系的能力。后量…

作者头像 李华
网站建设 2026/1/24 15:29:07

QProcess::finished

1.QProcess::finishedQProcess::finished 是 Qt 框架中 QProcess 类的一个信号,用于在进程执行完毕时通知应用程序。以下是关键要点及使用示例:核心机制信号触发时机当通过 QProcess 启动的外部进程结束(无论正常退出还是被终止)时…

作者头像 李华