恭喜发现宝藏!微信搜索公众号【TechGuide】关注更多新鲜好文和互联网大厂的笔经面经。 作者@TechGuide【全网同名】 点赞再看,养成习惯,您动动手指对原创作者意义非凡🤝
当你的才华还撑不起你的野心时,你应该静下心去学习 。🤝点赞再看,养成习惯🤝 前言基于Redis的分布式锁是用于解决缓存击穿的一个有效方法,原理也很简单,利用了第三方数据库对键值的唯一约束性以及redis的单线程模型,保证了单次单线程对缓存内容的访问,作为分布式锁引入实际项目可以解决诸如超卖等业务问题,关于分布式锁的一个具体实现可以查看我的Github仓库。
正文整合Redis基本步骤:
redisTemplate
使用(涉及到序列化与反序列化):
存在问题:
本地加锁解决缓存击穿问题:
本地锁存在的问题: 引出分布式锁
a) 分布式锁阶段一: 分布式锁的最简单实现:
b) 分布式锁阶段二:
占锁和设置过期时间必须是一个原子操作,否则两步之间有异常,则可能导致锁无法释放的问题。
c) 分布式锁阶段三:
问题:
- 锁的唯一性标志,保证删锁同一个线程。
- 同时要保证比较唯一性标志和删除锁的两步具有原子性。
- 要保证第二步,需要执行以下lua脚本
d) 分布式锁阶段四-最终阶段:
总结: 对于分布式锁来说,加锁和解锁都需要达到操作的原子性。 并且设置过期时间防止死锁也很必要。 但是,对于终极问题:过期时间到,业务还未执行结束。自动续期并不重要,指定一个较大的过期时间即可。
(以上截图全部取自雷神的教学视频课,感恩。)