Spring分布式事务如何处理的

第一种方案:可靠消息最终一致性。需要业务系统结合MQ消息中间件实现,在实现过程中需要保证消息的成功发送及成功消费。即需要通过业务系统控制MQ的消息状态。

第二种方案:TCC补偿性。分为三个阶段TRYING-CONFIRMING-CANCELING.每个阶段做不同的处理。

TRYING阶段主要是对业务系统进行检测及资源预留

CONFIRMING阶段是做业务提交,通过TRYING阶段执行成功后,再执行该阶段。默认如果TRYING阶段执行成功,CONFIRMING就一定能成功。

CANCELING阶段就是回对业务做回滚,在TRYING阶段中,如果存在分支事务TRYING失败,则需要调用CANCELING将已预留的资源进行释放。

posted @ 2020-09-26 02:10  SimonShixinlong  阅读(230)  评论(0)    收藏  举报