news 2026/4/18 3:29:10

【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/4/18 3:26:36

OpenCore Legacy Patcher终极指南:让老旧Mac重获新生的完整教程

还在为那些被Apple官方抛弃的老旧Mac发愁吗?看着2012年之前的MacBook、iMac无法升级到最新的macOS系统,是不是觉得它们已经走到了生命的尽头?别担心,OpenCore Legacy Patcher(OCLP)这款神奇的工具将彻底改变…

作者头像 李华
网站建设 2026/4/17 6:52:17

Mammoth.js:轻松将Word文档转换为HTML的完美解决方案

Mammoth.js:轻松将Word文档转换为HTML的完美解决方案 【免费下载链接】mammoth.js Convert Word documents (.docx files) to HTML 项目地址: https://gitcode.com/gh_mirrors/ma/mammoth.js 还在为Word文档的在线展示而烦恼吗?Mammoth.js正是你需…

作者头像 李华
网站建设 2026/4/16 10:47:15

Shutter Encoder深度解析:从技术架构到实战应用的完整指南

Shutter Encoder深度解析:从技术架构到实战应用的完整指南 【免费下载链接】shutter-encoder A professional video compression tool accessible to all, mostly based on FFmpeg. 项目地址: https://gitcode.com/gh_mirrors/sh/shutter-encoder 你是否曾经…

作者头像 李华
网站建设 2026/4/17 19:11:30

5分钟精通资源嗅探:零基础掌握跨平台下载神器终极指南

在日常网络冲浪中,你是否遇到过这样的困扰:想要保存喜欢的视频却发现无法下载?看到精彩的音频资源却束手无策?现在,这些问题都有了完美的解决方案。本文将带你深入了解一款功能强大的资源嗅探工具,让你轻松…

作者头像 李华
网站建设 2026/3/31 15:18:36

recaptcha v3 简单分析

声明: 本文章中所有内容仅供学习交流使用,不用于其他任何目的,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!部分python代码cp execjs.compile(ope…

作者头像 李华
网站建设 2026/4/15 18:21:58

Windows热键冲突终极解决方案:一键检测占用进程的完整指南

Windows热键冲突终极解决方案:一键检测占用进程的完整指南 【免费下载链接】hotkey-detective A small program for investigating stolen hotkeys under Windows 8 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 在日常使用Windows系统时&…

作者头像 李华