SpringCloud 实现 Restful Tcc

微服务分布式事务方案有很多二/三阶段提交,TCC,Restful TCC ,最终一致性,最大努力尝试型等等,

各有优缺点;这里就简单介绍下RestFul TCC ,

RESTful TCC是由Atomikos对微服务分布式事务提出的解决方案;

分三个阶段

  1. Trying阶段主要针对业务系统检测及作出预留资源请求, 若预留资源成功, 则返回确认资源的链接与过期时间
  2. Confirm阶段主要是对业务系统的预留资源作出确认, 要求TCC服务的提供方要对确认预留资源的接口实现幂等性, 若Confirm成功则返回204, 资源超时则证明已经被回收且返回404
  3. Cancel阶段主要是在业务执行错误或者预留资源超时后执行的资源释放操作, Cancel接口是一个可选操作, 因为要求TCC服务的提供方实现自动回收的功能, 所以即便是不认为进行Cancel, 系统也会自动回收资源

175915_0wNt_3260714.png

 

例子: https://github.com/zhaoqilong3031/spring-cloud-samples

转载于:https://my.oschina.net/u/3260714/blog/883194

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值