INFO
作者: 编程界的小学生
日期: 2021/09/05
修订: 初版,未修订。2021/09/05
版权: 内部资料,切勿泄漏,违者必究。
一、原理
mysql分布式锁主要实现核心就是利用唯一索引插入重复数据会报错来实现。插入冲突后就代表并发了,然后就休息一段时间继续重试,或者不休息直接CAS进行重试,插入成功后就代表抢锁成功,执行完后需要释放锁。(如果没看明白的话不要紧,下一篇会介绍mysql实现分布式锁的核心伪代码以及原理)
不符合【分布式锁必须具备的东西】中的如下两点:
- 高性能(Mysql性能肯定是低下的)
- 可重入(当然搞个计数器也可以实现可重入,但是高性能是得不到保障)
需要注意如下几点:
- 每个系统都需要重新创建个表,来存放锁,需要加事务保证原子性。
- 一定要写个定时器定时检查那些由于意外宕机或者其他外