分布式事务XA、TCC、AT总结
2021/12/23 23:13:03
本文主要是介绍分布式事务XA、TCC、AT总结,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
TCC和AT在第一阶段都会直接将事务提交(commit),如果需要回滚,TCC则需要在Cancel阶段自己实现一段业务逻辑来完成数据的回滚。注意,此时是写补偿sql来完成回滚保证数据的一致性。
而AT模式会将一阶段执行的sql记录在undo_log表中,然后通过整个undo_log来自动完成回滚,不需要程序员手动写补偿代码。这样也是阿里首推AT模式的原因,一个注解即可搞定分布式事务。
其次,TCC可以不依赖于关系型数据库,比如我们的远程操作可能是操作Redis、MongoDB等。因为TCC中的各阶段的逻辑都是我们手动来实现的,所以可以不依赖于数据库事务。
而AT模式必须要依赖于数据库事务,也就是说远程服务的方法必须加@Transaction
注解,这样TM才能感知到。
这篇关于分布式事务XA、TCC、AT总结的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享