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

雪崩

概念

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

如何避免

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

穿透

概念

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

如何避免

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

击穿

概念

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

如何避免

  • 缓存不过期
  • 互斥锁

区别

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

思维导图

相关推荐
FL4m3Y4n16 分钟前
MySQL缓存策略
数据库·mysql·缓存
野犬寒鸦40 分钟前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
野犬寒鸦2 小时前
Redis热点key问题解析与实战解决方案(附大厂实际方案讲解)
服务器·数据库·redis·后端·缓存·bootstrap
菜菜小狗的学习笔记5 小时前
黑马程序员Redis--实战篇(黑马点评)
数据库·redis·缓存
zz-zjx5 小时前
harbor使用外置db,redis,存储(minio)通过pigsty安装(单机)
数据库·redis·缓存
CDN3607 小时前
CDN 缓存不生效 / 内容不更新?7 种原因 + 一键刷新方案
运维·网络安全·缓存
清水白石0088 小时前
《Python 性能优化实战:多进程并行 vs C/Rust/Cython 扩展的对比决策与团队落地指南》
python·spring·缓存
红云梦9 小时前
互联网三高-高性能之多级缓存架构
java·redis·缓存·架构·cdn
歪瑞马奇9 小时前
Course17:SGLang 深度优化:Radix 缓存与复杂任务的极致吞吐
缓存
小松加哲10 小时前
Spring AOP 代理创建时机深度解析:初始化阶段 vs 三级缓存(源码级)
java·spring·缓存