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 并设置永不过期,

相关推荐
小小工匠7 小时前
Redis - 缓冲区管理:避免溢出引发的“惨案“
redis·性能优化·集群·内存管理·持久化
小小工匠8 小时前
Redis - 缓存与数据库一致性:问题分析与解决方案
redis·缓存·性能优化·消息队列·并发
闪电悠米8 小时前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
折哥的程序人生 · 物流技术专研8 小时前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
IT策士8 小时前
Redis 从入门到精通:数据结构Set 与 Sorted
数据结构·数据库·redis
填满你的记忆8 小时前
10万QPS下,Redis缓存如何避免雪崩?
数据库·redis·缓存
10WTW019 小时前
QQ本地缓存机制初步探寻
缓存·视频·md5
IT策士9 小时前
Redis 从入门到精通:数据结构String 与键管理
数据结构·redis·wpf
2601_961194029 小时前
考研专业课在哪里参加考试|考点|流程|资料已整理
linux·考研·ubuntu·缓存·centos·负载均衡
闪电悠米10 小时前
黑马点评-Redis 消息队列-01_why_redis_mq
java·数据库·spring boot·redis·缓存·junit·消息队列