Redis中的缓存穿透、缓存击穿、缓存雪崩(面试版)

缓存穿透

缓存穿透:查询一个不存在的数据,在mysql数据库中查询不到数据也不会写入缓存,导致每次请求都查询数据库,增加数据库负载。

解决办法:

1、**缓存空值:**将数据库中不存在的结果(例如空值)也缓存起来,并设置一个较短的过期时间,避免频繁查询数据库

2、**使用布隆过滤器:**使用布隆过滤器来快速判断一个请求的数据是否存在,如果布隆过滤器判断数据不存在,则直接返回,避免查询数据库。

  • 布隆过滤器原理:

3、防止非法请求:检查非法请求,封禁其IP以及账号

缓存击穿

缓存击穿: 给某一个key设置了过期时间,当key过期的时候,恰好对这个key有大量的请求过来,这些并发的请求可能会瞬间把DB压垮

解决办法:

1)加互斥锁:保证同一时间只有一个请求来构建缓存,跟缓存雪崩相同。

2)热点数据永不过期:不要给热点数据设置过期时间,在后台异步更新缓存

缓存雪崩

缓存雪崩是指在某个时间点,大量缓存同时失效或被清空,导致大量请求到达数据库或后端系统,造成系统负载激增,甚至引发系统崩溃,这通常是由于缓存中的大量数据在同一时间失效引起的。

解决办法:

1、**设置过期时间随机化:**设置缓存的过期时间,加上一个随机值,避免同一时间大量缓存失效。

2、**使用多级缓存:**引入多级缓存,如Guava或Caffeine作为一级缓存,redis作为二级缓存。

3、**构建集群:**构建多个 Redis 集群提高服务的可用性

相关推荐
qq_2816842124 分钟前
Apt-Serve:基于混合缓存与自适应调度突破LLM推理KV缓存瓶颈,吞吐量提升8.8倍
缓存
肆忆_24 分钟前
【面试】手撕线程池
面试
wangfpp25 分钟前
性能优化,请先停手:为什么我劝你别上来就搞优化?
前端·javascript·面试
野犬寒鸦39 分钟前
JVM垃圾回收机制面试常问问题及详解
java·服务器·开发语言·jvm·后端·算法·面试
奕成则成1 小时前
面试被问:MySQL 与 Doris/SelectDB 的架构区别。 大数据为什么禁止select *。
mysql·面试·架构
AlunYegeer2 小时前
面试问题controller和service能不能互相替换
面试·职场和发展
1104.北光c°2 小时前
深入浅出 Elasticsearch:从搜索框到精准排序的架构实战
java·开发语言·elasticsearch·缓存·架构·全文检索·es
知识分享小能手2 小时前
Redis入门学习教程,从入门到精通, Redis Stack 完整语法知识点及使用指南(7)
数据库·redis·学习
MSTcheng.2 小时前
【优选算法必修篇——位运算】『面试题 01.01. 判定字符是否唯一&面试题 17.19. 消失的两个数字』
java·算法·面试
一个有温度的技术博主2 小时前
Redis系列八:Jedis连接池在java中的使用
java·redis·bootstrap