首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

.Net Core with 微服务 - 分布式事务 - 2PC、3PC

最近比较忙,好久没更新了。这次我们来聊一聊分布式事务。 在微服务体系下,我们的应用被分割成多个服务,每个服务都配置一个数据库。如果我们的服务划分的不够完美,那么为了完成业务会出现非常多的跨库事务。即使按照 DDD 的原则来切分服务还是免不了有的业务场景需要多个业务同时提交成功或者同时回滚的场景。比如会员使用积分下订单这个场景,那么会员服务的积分扣减需要跟订单下单成功同时完成。如果下单成功,但是扣减积分接口失败,那么就会造成数据的不一致性。这个时候我们就需要使用分布式事务来保证数据的一致性。 由于分布式事务要介绍的东西比较多,这一篇只介绍 2PC、3PC 的基本概念,所以 .net 相关的内容大概也只会出现在标题上一次,笑哭。

04
您找到你想要的搜索结果了吗?
是的
没有找到

XA事务prepare和commit执行顺序要求,以及两阶段提交协议(2PC)和三阶段提交协议(3PC)在分布式事务中的作用和区别

按照prepare和commit的顺序执行是为了确保事务的原子性和一致性。 在prepare阶段,事务参与者会执行事务操作,并将操作记录到事务日志中,但是并不会真正提交事务,以避免发生不可恢复的错误。只有在所有参与者都能成功执行prepare操作后,事务协调器才会通知参与者进行commit操作,这样可以保证所有参与者都已经准备好提交事务。如果先执行commit操作而没有经过prepare阶段,可能会导致数据的不一致性,因为有些参与者还没有准备好提交事务。因此,为了保证事务的一致性,正常情况下应按照prepare和commit的顺序执行。

04
领券