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

雪崩

概念

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

如何避免

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

穿透

概念

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

如何避免

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

击穿

概念

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

如何避免

  • 缓存不过期
  • 互斥锁

区别

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

思维导图

相关推荐
Benny的老巢33 分钟前
Chrome 缓存迁移教程:5种方法解决 C 盘空间不足问题(2026年最新)
c语言·chrome·缓存
oMcLin44 分钟前
如何在 RHEL 8 上搭建高效的 Redis 集群,支持跨地域的数据同步与低延迟缓存访问?
数据库·redis·缓存
报错小能手1 小时前
线程池学习(四)实现缓存线程池(Cached ThreadPool)
java·学习·缓存
山沐与山1 小时前
【Redis】双重判定锁详解:缓存击穿的终极解决方案
java·redis·缓存
咖丨喱1 小时前
【解析并缓存 P2P_ATTR_DEVICE_INFO】
缓存·asp.net·p2p
C_心欲无痕11 小时前
浏览器缓存: IndexDB
前端·数据库·缓存·oracle
虫小宝12 小时前
优惠券省钱app高并发秒杀系统:基于Redis与消息队列的架构设计
数据库·redis·缓存
少许极端13 小时前
Redis入门指南(五):从零到分布式缓存-其他类型及Java客户端操作redis
java·redis·分布式·缓存
C_心欲无痕15 小时前
网络相关 - 强缓存与协商缓存讲解
前端·网络·网络协议·缓存
三两肉15 小时前
HTTP 缓存详解
网络协议·http·缓存