分布式事务之TCC处理

本文探讨了TCC(Try-Confirm-Cancel)模式在分布式事务中的应用,包括空回滚、悬挂、幂等性等问题。提出了通过记录分支事务状态来识别空回滚,以及在Try阶段防止悬挂事务的策略。同时强调了幂等性的重要性,通过跟踪执行状态确保操作的幂等性。
摘要由CSDN通过智能技术生成

只要try成功,认为confirm成功,如果confirm出错,需要重试或人工处理

cancal阶段在业务执行错误需要回滚的状态下,会执行分支事务的业务取消,预留资源释放。认为cancel也是成功的,失败要重试或人工处理

空回滚

     原因: 没有调用try 方法,直接调用cancel方法

     解决方案:解决思路是关键就是要识别出这个空回滚。思路很简单就是需要知道一阶段是否执行,如果执行了,那就是正常回滚;如果没执行,那就是空回滚。前面已经说过TM在发起全局事务时生成全局事务记录,全局事务ID贯穿整个分 布式事务调用链条。再额外增加一张分支事务记录表,其中有全局事务 ID 和分支事务 ID,第一阶段 Try 方法里会 插入一条记录,表示一阶段执行了。Cancel 接口里读取该记录,如果该记录存在,则正常回滚;如果该记录不存在,则是空回滚。

      

悬挂

     原因:在事务中,cancel接口比try接口先执行了

     解决方案:如果二阶段执行完成,那一阶段就不能再继续执行。在执行一阶段事务时判断在该全局事务下,“分支事务记录”表中是否已经有二阶段事务记录,如果有则不执行Try。

 

幂等

      原因:为了保证TCC二阶段提交重试机制不会引发数据不一致,要求 TCC 的二阶段 Try、Confirm 和 Cancel 接口保证幂等,这样不会重复使用或者释放资源。如果幂等控制没有做好,很有可能导致数据不一致等严重问题

      解决方案:“分支事务记录“表中增加执行状态,每次执行前都查询该状态

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值