缓存雪崩、穿透、击穿的概念和如何避免

雪崩

概念

高并发请求多个key,此时多个key同时失效、不在缓存中,请求全部打到数据库,使数据库无法处理这么多的连接,导致数据库死机

如何避免

  • 防止多个key同时过期,设置随机的过期时间
  • 不设置过期时间,有更新时更新维护到最新

穿透

概念

请求数据在缓存和数据库中都不存在,大量请求打到缓存和数据库,造成缓存和数据库处理大量请求导致服务器死机

如何避免

  • 不查库的参数校验,过滤掉非法数据
  • 不存在的数据,在缓存中存放默认值表示数据不存在,通过缓存来减少数据库请求量
  • 使用布隆过滤器来判断一个记录是否存在

击穿

概念

高并发请求一个key,此时该key过期、不存在缓存中,大量并发请求打到数据库,造成数据库死机

如何避免

  • 缓存不过期
  • 互斥锁

区别

  • 雪崩是多个key同时过期,而打到数据库;
  • 穿透是key既打到缓存又打到数据库;
  • 击穿是大并发请求单个key,造成缓存和数据库都处理大量请求

思维导图

相关推荐
Zfox_12 小时前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
呼拉拉呼拉12 小时前
Redis内存淘汰策略
redis·缓存
咖啡啡不加糖16 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
肥仔哥哥193017 小时前
springCloud2025+springBoot3.5.0+Nacos集成redis从nacos拉配置起服务
redis·缓存·最新boot3集成
呼拉拉呼拉19 小时前
Redis故障转移
数据库·redis·缓存·高可用架构
篱笆院的狗1 天前
如何使用 Redis 快速实现布隆过滤器?
数据库·redis·缓存
Alla T1 天前
【前端】缓存相关
前端·缓存
chen.@-@1 天前
后端下载限速(redis记录实时并发,bucket4j动态限速)
数据库·redis·缓存
吾日三省吾码1 天前
Spring 团队详解:AOT 缓存实践、JSpecify 空指针安全与支持策略升级
java·spring·缓存
不凡的凡2 天前
鸿蒙图片缓存(一)
缓存