本文作者:小米,一个热爱技术分享的29岁程序员。如果你喜欢我的文章,欢迎关注我的微信公众号“软件求生”,获取更多技术干货!
Hello,大家好!我是你们的技术小伙伴小米,今天我们一起来聊一聊“分布式事务”这个话题。最近收到不少朋友的留言,说在实际项目中遇到了分布式事务的问题,尤其是在选择合适的方案上感到困惑。今天我就来和大家分享一下常见的分布式事务解决方案,以及它们在不同场景下的应用。
分布式事务概述
在分布式系统中,事务的处理相较于单体应用要复杂得多。由于数据分散在不同的节点上,要确保事务的ACID特性(原子性、一致性、隔离性、持久性)就变得非常困难。为了解决这个问题,业界提出了多种分布式事务解决方案,每种方案都有其适用的场景。
严格资金要求场景:TCC 方案
首先,我们来看一个严格资金要求的场景,例如银行转账系统。在这个场景中,任何错误都会导致严重的后果,因此我们需要一种能够保证绝对一致性的事务处理方案。
什么是 TCC?
TCC(Try-Confirm-Cancel)是一种比较严格的分布式事务解决方案,它将一个事务分为三个阶段:
- Try 阶段:预留资源或者预处理业务逻辑。
- Confirm 阶段:确认并提交