Redis框架(七):大众点评项目 缓存穿透、缓存击穿、缓存雪崩
创始人
2024-04-22 20:00:03
0

大众点评项目 缓存穿透、缓存击穿、缓存雪崩

  • 需求:缓存穿透、缓存击穿、缓存雪崩
  • 处理策略
    • 缓存穿透处理
    • 缓存雪崩
    • 缓存击穿
  • 总结

SpringCloud章节复习已经过去,新的章节Redis开始了,这个章节中将会回顾Redis实战项目 大众点评
主要依照以下几个原则

  1. 基础+实战的Demo和Coding上传到我的代码仓库
  2. 在原有基础上加入一些设计模式,stream+lamdba等新的糖
  3. 通过DeBug调试,进入组件源码去分析底层运行的规则和设计模式

代码会同步在我的gitee中去,觉得不错的同学记得一键三连求关注,感谢:
Redis优化-链接: RedisThreeStrategiesProject
在这里插入图片描述

需求:缓存穿透、缓存击穿、缓存雪崩

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

处理策略

缓存穿透处理

  1. 布隆过滤器:本质上是一个概率运算器,可以将存储的数据分解成二进制数据,来进行推测传入数据是否存在,有一定不确定性,但是如果判断为不存在,则一定不存在;
  2. 添加Null值
    在这里插入图片描述
        //处理缓存穿透: id范围就在0-10000if (id <= 0 || id> 10000) {return Result.fail("店铺类型不存在!");}

添加Null值

            if (shop == null) {//处理缓存穿透stringRedisTemplate.opsForValue().set(key, "",  RedisConstants.CACHE_NULL_TTL, TimeUnit.MINUTES);return Result.fail("店铺类型不存在!");}

判断Null值

        //处理缓存穿透: 如果为空值if (shopStr != null){return Result.fail("店铺类型不存在!");}

缓存雪崩

  1. 可以设置随机时间
  2. 设置异地多活,主从架构等方式
        //处理缓存雪崩: 随机时间 time * RedisConstants.CACHE_NULL_TTLRandom random = new Random();Long time = random.nextLong();
                stringRedisTemplate.opsForValue().set(key, "", time *  RedisConstants.CACHE_NULL_TTL, TimeUnit.MINUTES);

缓存击穿

如果当前热点信息失效,大量访问就落在DB上,我们可以通过

  1. 互斥锁(setnx)
  2. 逻辑过期机制
    在这里插入图片描述
        //互斥锁处理缓存击穿String lockKey = RedisConstants.LOCK_SHOP_KEY + id;try {if (!tryLock(stringRedisTemplate.opsForValue().setIfAbsent(key, "1", RedisConstants.LOCK_SHOP_TTL, TimeUnit.SECONDS))) {Thread.sleep(50);return queryById(id);}log.debug("lockKey" + lockKey);shop = getById(id);stringRedisTemplate.opsForValue().set(key, JSONUtil.toJsonStr(shop),   RedisConstants.CACHE_NULL_TTL, TimeUnit.HOURS);} catch (InterruptedException e) {throw new RuntimeException(e);/*e.printStackTrace();*/}finally {//删除暂时的key, 释放互斥锁stringRedisTemplate.delete(lockKey);}

所有代码

   @Overridepublic Result queryById(Long id) {//处理缓存穿透: id范围就在0-10000if (id <= 0 || id> 10000) {return Result.fail("店铺类型不存在!");}String key = RedisConstants.CACHE_SHOP_KEY + id;String shopStr = stringRedisTemplate.opsForValue().get(key);if(StrUtil.isNotBlank(shopStr)){Shop shop = JSONUtil.toBean(shopStr, Shop.class);return Result.ok(shop);}//处理缓存穿透: 如果为空值if (shopStr != null){return Result.fail("店铺类型不存在!");}//处理缓存雪崩: 随机时间 time * RedisConstants.CACHE_NULL_TTLRandom random = new Random();Long time = random.nextLong();Shop shop = null;//互斥锁处理缓存击穿String lockKey = RedisConstants.LOCK_SHOP_KEY + id;try {if (!tryLock(lockKey)) {Thread.sleep(50);return queryById(id);}log.debug("lockKey" + lockKey);shop = getById(id);if (shop == null) {//处理缓存穿透stringRedisTemplate.opsForValue().set(key, "",  RedisConstants.CACHE_NULL_TTL, TimeUnit.MINUTES);return Result.fail("店铺类型不存在!");}stringRedisTemplate.opsForValue().set(key, JSONUtil.toJsonStr(shop),   RedisConstants.CACHE_NULL_TTL, TimeUnit.HOURS);} catch (InterruptedException e) {throw new RuntimeException(e);/*e.printStackTrace();*/}finally {//删除暂时的key, 释放互斥锁stringRedisTemplate.delete(lockKey);}return Result.ok(shop);}public boolean tryLock(String key){Boolean flag = stringRedisTemplate.opsForValue().setIfAbsent(key, "1", RedisConstants.LOCK_SHOP_TTL, TimeUnit.SECONDS);//这里不可以直接返回flag,因为在拆箱过程中可能出现flag为null的情况;return BooleanUtil.isTrue(flag);}

总结

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

相关内容

热门资讯

安卓子系统windows11,... 你知道吗?最近科技圈可是炸开了锅,因为安卓子系统在Windows 11上的兼容性成了大家热议的话题。...
电脑里怎么下载安卓系统,电脑端... 你有没有想过,你的电脑里也能装上安卓系统呢?没错,就是那个让你手机不离手的安卓!今天,就让我来带你一...
索尼相机魔改安卓系统,魔改系统... 你知道吗?最近在摄影圈里掀起了一股热潮,那就是索尼相机魔改安卓系统。这可不是一般的改装,而是让这些专...
安卓系统哪家的最流畅,安卓系统... 你有没有想过,为什么你的手机有时候像蜗牛一样慢吞吞的,而别人的手机却能像风一样快?这背后,其实就是安...
安卓最新系统4.42,深度解析... 你有没有发现,你的安卓手机最近是不是有点儿不一样了?没错,就是那个一直在默默更新的安卓最新系统4.4...
android和安卓什么系统最... 你有没有想过,你的安卓手机到底是用的是什么系统呢?是不是有时候觉得手机卡顿,运行缓慢,其实跟这个系统...
平板装安卓xp系统好,探索复古... 你有没有想过,把安卓系统装到平板上,再配上XP系统,这会是怎样一番景象呢?想象一边享受着安卓的便捷,...
投影仪装安卓系统,开启智能投影... 你有没有想过,家里的老式投影仪也能焕发第二春呢?没错,就是那个曾经陪你熬夜看电影的“老伙计”,现在它...
安卓系统无线车载carplay... 你有没有想过,开车的时候也能享受到苹果设备的便利呢?没错,就是那个让你在日常生活中离不开的iOS系统...
谷歌安卓8系统包,系统包解析与... 你有没有发现,手机更新换代的速度简直就像坐上了火箭呢?这不,最近谷歌又发布了安卓8系统包,听说这个新...
微软平板下软件安卓系统,开启全... 你有没有想过,在微软平板上也能畅享安卓系统的乐趣呢?没错,这就是今天我要跟你分享的神奇故事。想象你手...
coloros是基于安卓系统吗... 你有没有想过,手机里的那个色彩斑斓的界面,背后其实有着一个有趣的故事呢?没错,我要说的就是Color...
安卓神盾系统应用市场,一站式智... 你有没有发现,手机里的安卓神盾系统应用市场最近可是火得一塌糊涂啊!这不,我就来给你好好扒一扒,看看这...
黑莓平板安卓系统升级,解锁无限... 亲爱的读者们,你是否还记得那个曾经风靡一时的黑莓手机?那个标志性的全键盘,那个独特的黑莓体验,如今它...
安卓文件系统采用华为,探索高效... 你知道吗?最近安卓系统在文件管理上可是有了大动作呢!华为这个科技巨头,竟然悄悄地给安卓文件系统来了个...
深度系统能用安卓app,探索智... 你知道吗?现在科技的发展真是让人惊叹不已!今天,我要给你揭秘一个超级酷炫的话题——深度系统能用安卓a...
安卓系统的分区类型,深度解析存... 你有没有发现,你的安卓手机里藏着不少秘密?没错,就是那些神秘的分区类型。今天,就让我带你一探究竟,揭...
安卓系统铠无法兑换,揭秘无法兑... 最近是不是有很多小伙伴在玩安卓系统的游戏,突然发现了一个让人头疼的问题——铠无法兑换!别急,今天就来...
汽车安卓系统崩溃怎么刷,一键刷... 亲爱的车主朋友们,你是否曾遇到过汽车安卓系统崩溃的尴尬时刻?手机系统崩溃还能重启,但汽车系统崩溃了,...
miui系统可以刷安卓p系统吗... 亲爱的手机控们,你是否对MIUI系统情有独钟,同时又对安卓P系统的新鲜功能垂涎欲滴?今天,就让我带你...