Redis 缓存穿透/缓存雪崩/缓存击穿问题

1.缓存预热

当 redis 服务器 首次接入时,服务器内是没有数据的-->当客户端发起请求时,所有的请求,都会访问 mysql 随着时间的推移,redis 上的 数据越来越多,mysql 承担的压力就会逐渐减小(客户端先查询 redis 如果没有查到,就再查询一次 mysql 查到了之后,就会把数据也写入到 redis 中);

如何解决?

缓存预热-->就是用来解决上述问题的:将定时生成 和 实时生成 相结合--先在离线的情况下,先把热点数据导入到 redis 中,此时 导入的这些热点数据,就能帮 mysql 承担很大的压力,随着时间的推移,逐渐使用新的热点数据,淘汰掉旧的数据;

2.缓存穿透

查询某个 key ,在 redis 中没有, mysql 中也没有--这个 key 也不会被更新到 redis 中

如何解决?

1.如果发现这个 key 在 redis 和mysql 中都不存在,就仍然写入到 redis 中 ,将 value 设置为一个空值(""),或者非法值;

2.引入 布隆过滤器,每次查询 redis / mysql 之前,先判断一下 key 是否在 布隆过滤器上存在;(布隆过滤器 本质 是 结合了 hash + bitmap 用比较小的空间开销,比较快的速度,实现针对 key 是否存在的判定)

3.缓存雪崩

由于在短时间内,redis 上大规模的 key 失效,导致缓存命中率 下降,并且 mysql 压力迅速上升;

4.缓存击穿

相当于缓存雪崩的特殊情况,针对热点 key 突然过期了,导致大量的请求直接访问到数据库上,甚至引起数据库当即

如何解决?

基于统计的方式发现热点 key 并设置永不过期,

相关推荐
Java开发的小李1 天前
SpringBoot + Redis 实现分布式 Session 共享(解决多实例登录状态丢失问题)
spring boot·redis·分布式
daixin88481 天前
cursor无法正常使用gpt5.5等模型解决方案
java·redis·cursor
小猿姐1 天前
Redis Kubernetes Operator 实测:三个方案的真实差距
redis·容器·kubernetes
亚马逊云开发者1 天前
EMR Core 节点部署 Flink Client 实战:Bootstrap Action 一次打包多次复用,解决调度系统提交任务的痛点
大数据·flink·bootstrap
TechWayfarer1 天前
IP归属地运营商生产落地进阶:缓存+降级+灰度对账全解析
网络·python·网络协议·tcp/ip·缓存
aLTttY1 天前
Spring Boot + Redis 实现接口防抖与限流实战指南
spring boot·redis·junit
Lyyaoo.1 天前
TreadLocal和TreadLocalMap
android·java·redis
为美好的生活献上中指1 天前
本地虚拟机部署redis集群
前端·redis·ubuntu·bootstrap·html·redis集群
coderlin_2 天前
Langgraph项目三 agent搭建
java·数据库·redis
田梓燊2 天前
力扣:146.LRU 缓存
算法·leetcode·缓存