mysql事务锁等待是公平锁吗_分布式事务以及锁(示例代码)

标题格

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社区等公众号。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值