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

雪崩

概念

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

如何避免

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

穿透

概念

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

如何避免

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

击穿

概念

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

如何避免

  • 缓存不过期
  • 互斥锁

区别

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

思维导图

相关推荐
zizisuo13 小时前
6.1.多级缓存架构
缓存·架构
JavaGuide15 小时前
腾讯Java后端一面,被速通了!
网络·http·缓存·程序员·idea·多线程·校招·java基础·并发编程·aio·计算机基础·认证授权
南隅。16 小时前
【Redis】基础2:作为缓存
redis·缓存
TE-茶叶蛋17 小时前
Redis 原子操作
数据库·redis·缓存
我科绝伦(Huanhuan Zhou)20 小时前
Nginx性能优化:从配置到缓存,全面提升Web服务器性能
nginx·缓存·性能优化
星星点点洲1 天前
【缓存与数据库结合最终方案】伪从技术
数据库·缓存
Ivan陈哈哈1 天前
Redis是单线程的,如何提高多核CPU的利用率?
数据库·redis·缓存
头顶秃成一缕光1 天前
Redis的主从模式和哨兵模式
数据库·redis·缓存
观无1 天前
Redis安装及入门应用
数据库·redis·缓存
XY.散人1 天前
初识Redis · 哨兵机制
数据库·redis·缓存