其他分享
首页 > 其他分享> > 分布式之TCC,2PC

分布式之TCC,2PC

作者:互联网

1.是什么?

     TCC和2PC都是分布式事务的一种实现方式,2者不同在于,TCC在业务层实现,而2PC在数据库中实现,例如innodb的XA。

 

2.为什么需要?

     如果我们用到了分布式的架构,那么通常就是一个服务一个数据库,我们都知道ACID在一个库中实现并不难,但是如果我们一个事务涉及到了多个数据库,例如下单这一过程,涉及到了账户数据库,库存数据库,怎样解决账户和库存数据库能够同时进行修改或者失败呢,这就是TCC和2PC解决的问题。

 

3.怎么做?

    不管是2PC还是TTC,都可分为3个操作,预留,确认,回滚。

    2PC:

            预留:首先向每个要操作的数据库发出预留请求,其实相当于一个加锁的操作,要注意一点,一旦预留成功,那么这个事务就必须成功,无论是服务器挂掉了还是后来提交失败了,一定要成功为止。

            提交:每一个事务一一提交。

            回滚:其中一个事务预留失败,集体回滚。

   TCC:其实和2PC差不多,只是在业务层上面实现,但是TCC更加灵活,为什么说他更加灵活呢?2PC从数据库的层面上加上了锁,所以在分布式事务完成之前,其他业务是没有可能读和写的,TCC其实不是加锁操作,更多的是封锁对该字段的读或者写操作,例如现在商品中库存这一字段,现在因为某一用户要购买该商品,进入了预留阶段,那么写操作肯定是不允许的,但是读操作可以吗?在实际中肯定是可以了,因为在一个商城中不可能说因为其中一个人在购买商品,在走购物流程,其他人对这个这个商品还有多少看不见,所以在这个流程的设计中,我们可以关闭写操作,而开放读操作(如果读和写都在同一字段的话),还要注意一点,一旦我们对某一个服务实现了TCC,那么所有的读写操作都应该走服务所提供的接口,因为一旦其他业务可以直接读写该服务所建立的数据库,那么TCC就失去了它的意义。         

 

标签:数据库,2PC,预留,操作,TCC,分布式
来源: https://blog.csdn.net/fbher/article/details/106734626