您当前的位置: 首页 >  缓存

TechGuide

暂无认证

  • 5浏览

    0关注

    176博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

redis缓存使用及分布式锁实现学习笔记(新手向纯干货)

TechGuide 发布时间:2020-12-16 01:51:37 ,浏览量:5

恭喜发现宝藏!微信搜索公众号【TechGuide】关注更多新鲜好文和互联网大厂的笔经面经。 作者@TechGuide【全网同名】 点赞再看,养成习惯,您动动手指对原创作者意义非凡🤝

当你的才华还撑不起你的野心时,你应该静下心去学习 。🤝点赞再看,养成习惯🤝 前言

基于Redis的分布式锁是用于解决缓存击穿的一个有效方法,原理也很简单,利用了第三方数据库对键值的唯一约束性以及redis的单线程模型,保证了单次单线程对缓存内容的访问,作为分布式锁引入实际项目可以解决诸如超卖等业务问题,关于分布式锁的一个具体实现可以查看我的Github仓库。

正文

整合Redis基本步骤: 在这里插入图片描述 在这里插入图片描述 redisTemplate使用(涉及到序列化与反序列化): 在这里插入图片描述 在这里插入图片描述 存在问题: 在这里插入图片描述 在这里插入图片描述 在这里插入图片描述 本地加锁解决缓存击穿问题: 在这里插入图片描述 在这里插入图片描述

本地锁存在的问题: 在这里插入图片描述 引出分布式锁

a) 分布式锁阶段一: 在这里插入图片描述 分布式锁的最简单实现: 在这里插入图片描述 b) 分布式锁阶段二: 在这里插入图片描述 占锁和设置过期时间必须是一个原子操作,否则两步之间有异常,则可能导致锁无法释放的问题。 在这里插入图片描述 在这里插入图片描述 c) 分布式锁阶段三:

问题:

  1. 锁的唯一性标志,保证删锁同一个线程。
  2. 同时要保证比较唯一性标志和删除锁的两步具有原子性。
  3. 要保证第二步,需要执行以下lua脚本 在这里插入图片描述 在这里插入图片描述 d) 分布式锁阶段四-最终阶段: 在这里插入图片描述

总结: 对于分布式锁来说,加锁和解锁都需要达到操作的原子性。 并且设置过期时间防止死锁也很必要。 但是,对于终极问题:过期时间到,业务还未执行结束。自动续期并不重要,指定一个较大的过期时间即可。

(以上截图全部取自雷神的教学视频课,感恩。)

关注
打赏
1665329535
查看更多评论
立即登录/注册

微信扫码登录

0.0371s