当前位置:首页 » 《随便一记》 » 正文

详解分布式事务解决方案之TCC机制_沸羊羊_

25 人参与  2021年11月19日 14:23  分类 : 《随便一记》  评论

点击全文阅读


前言

之前讲解了分布式事务的解决方案之2PC和3PC,今天主要讲解事务补偿机制(TCC),Let's go !

TCC

TCC 事务补偿是基于 2PC 实现的业务层事务控制方案,它是 try, Confirm, Cancel 三个单词的首字母,含义如下:

  • try 检查及预留业务资源完成提交事务前的检查,并预留好资源
  • confirm 确定执行业务操作,对 try 阶段预留的资源正式执行
  • cancel 取消执行业务操作,对 try 阶段预留的资源进行释放

image.png

将 TCC 机制带进业务为例:

1、try

下单业务由订单服务和库存服务协同完成,在 try 阶段订单服务和库存服务完成检查和预留资源

比如:订单服务检查当前是否可以满足提交订单,库存服务检查是否有充足的库存,并锁定资源

2、confirm

订单服务和库存服务成功完成 try 后开始正式执行资源操作。

比如:订单服务写入一条订单信息,库存服务扣除库存

3、cancel

订单服务和库存服务有一方出现失败则全部取消操作。

比如:订单服务需删除新增的订单信息,库存还原扣除的库存

特点

TCC 机制优点:

  • 最终保证数据一致性,在业务层实现事务控制,灵活性好

TCC 机制缺点:

  • 开发成本高,每个事务操作每个参与者都需要实现 try/commit/cancel 三个接口

由于 try,confirm,cancel 三个阶段中失败后要不断重试,所以 TCC 的 try,confirm,cancel 的三个接口都要实现幂等性。

幂等性

幂等性是指同一个操作无论请求多少次,其结果都相同。

保证幂等性的方案如下:

1、操作前在业务系统进行判断如果执行过了就不再执行

2、缓存所有请求和处理的结果,已经处理的请求则直接返回结果

3、在数据库表中添加一个状态字段,数据操作时判断处理状态


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/31039.html

服务  库存  订单  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 完结文我在恐怖游戏开裁缝铺列表_完结文我在恐怖游戏开裁缝铺(林慕秋)
  • 全书免费谢清禾姜博诚_谢清禾姜博诚全书免费
  • 离婚后我收获真爱,前妻却快死了(秦落音陆轩),离婚后我收获真爱,前妻却快死了
  • 老公把上亿豪宅送养妹后,我把人和房都拆了(顾思思顾言洲)全书免费_(顾思思顾言洲)老公把上亿豪宅送养妹后,我把人和房都拆了后续(顾思思顾言洲)
  • 沈星悦傅时安_沈星悦傅时安
  • 离婚后,居然还能以旧换新?(陈汉李淼淼李思)全书浏览_离婚后,居然还能以旧换新?全书浏览
  • 完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道列表_完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道(秦薇)
  • 全书浏览老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)_老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)全书结局
  • 全文无边怨恨是她活下来的最大动力(江寒静顾榕赫)列表_全文无边怨恨是她活下来的最大动力
  • 全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产(顾霆锋顾青卿)列表_全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产
  • 霍晚清赵旭然_霍晚清赵旭然
  • 弟弟看的破茧时光沉淀后的深情相拥林悦苏然全书在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1