码迷,mamicode.com
首页 > 其他好文 > 详细

分布式事务以及锁

时间:2018-12-18 11:03:18      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:社区   资源   架构   回滚   数据库   公众   ant   bsp   ring   

标题格

  1、非公平锁

  2、TCC分布式事务原理

1、非公平锁
  在加锁过程,线程1运行,线程2处于等待队列。 线程1运行结束,结果线程3抢先于线程2进行。这就是非公平锁的简单含义。
  在ReentrantLock lock = new ReentrantLock()默认的就是非公平锁,构造函数中加入true:ReentrantLock lock = new ReentrantLock(true)。
  公平锁原则就是线程3就绪后,会先查看等待队列是否有线程,有就排队。

2、TCC分布式事务原理
  使用springcloud微服务,也有可能各个服务之间,没有形成一个整体的事务
  分步实现:
    1)、try阶段:多个服务之间,在操作的时候对数据库的操作都是一个"预"操作阶段,锁定某个资源,冻结某部分资源等(把改变的数据先存

    临时表)
    2)、confirm阶段:如果服务全部通过,依靠TCC分布式事务框架来执行---加入一个confirm类,提供一个接口,将刚刚的临时表数据,变为对

    数据库真实的操作。(完成所有逻辑)

    3)、Cancel阶段:如果某个服务挂了---也是提供一个接口,将临时表中的数据,恢复到原数据库中。(回滚所有逻辑)
    该事务适用于同步操作

 

参考:纯洁的微笑、石杉的架构笔记、java版web项目、架构师之路、springForAll社区等公众号。

分布式事务以及锁

标签:社区   资源   架构   回滚   数据库   公众   ant   bsp   ring   

原文地址:https://www.cnblogs.com/AlmostWasteTime/p/10134993.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!