如何用MySQL实现一把分布式锁?

本文介绍了如何利用MySQL的唯一索引插入冲突来实现分布式锁,强调了这种方式在高性能和可重入方面的不足,并给出了简单的伪代码。同时,提醒注意需要创建专门的锁表并设置事务以保证原子性,以及防止死锁的定时清理机制。尽管不适用于高并发场景,但为理解分布式锁的原理提供了思路。
摘要由CSDN通过智能技术生成

INFO

作者: 编程界的小学生

日期: 2021/09/05

修订: 初版,未修订。2021/09/05

版权: 内部资料,切勿泄漏,违者必究。

一、原理

mysql分布式锁主要实现核心就是利用唯一索引插入重复数据会报错来实现。插入冲突后就代表并发了,然后就休息一段时间继续重试,或者不休息直接CAS进行重试,插入成功后就代表抢锁成功,执行完后需要释放锁。(如果没看明白的话不要紧,下一篇会介绍mysql实现分布式锁的核心伪代码以及原理)

不符合【分布式锁必须具备的东西】中的如下两点:

  • 高性能(Mysql性能肯定是低下的)
  • 可重入(当然搞个计数器也可以实现可重入,但是高性能是得不到保障)

需要注意如下几点:

  • 每个系统都需要重新创建个表,来存放锁,需要加事务保证原子性。
  • 一定要写个定时器定时检查那些由于意外宕机或者其他外界原因导致锁一直没释放的那些数据。防止死锁。
  • 并发小的场景能用,并发下千万别用。因为他每次都是写表操作,效率很低。mysql容易卡死。

二、代码实现

只是伪代码来说明原理,Mysql的方式也不建议用在生产环境下,效率低

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

【原】编程界的小学生

没有打赏我依然会坚持。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值