Redis缓存雪崩、缓存击穿、缓存穿透详解

 更新时间:2025年07月22日 09:11:23   作者:在成都搬砖的鸭鸭  
本文介绍了缓存雪崩、击穿、穿透三种问题:雪崩因大量缓存同时失效导致数据库压力激增,需差异化TTL、多级缓存及熔断机制;击穿由热点key失效引发,可用互斥锁、逻辑过期或预加载;穿透则因非法查询穿透缓存,需布隆过滤器、空对象或参数校验

1、缓存雪崩

【1】定义

大量缓存数据在同一时间失效,导致所有请求直接打到数据库,引发数据库瞬时高负载甚至崩溃

【2】原因

1、缓存数据设置了相同的过期时间

2、缓存服务宕机

【3】解决方案

[1]差异化过期时间

在基础TTL上增加随机值,避免同时失效

[2]多级缓存

结合本地缓存和分布式缓存,本地缓存失效后回源到分布式缓存

[3]熔断降级

监控数据库负载,超过阈值时触发熔断(如返回默认值或限流)

[4]缓存永不过期+异步更新

缓存不设TTL,通过后台任务定期更新(适合低频变更数据)

2、缓存击穿

【1】定义

某个热点key突然失效,大量并发请求直接穿透到数据库,导致数据库压力激增

【2】原因

1、热点key过期

2、恶意请求故意攻击高频访问的key

【3】解决方案

[1]互斥锁

第一个请求发现缓存失效时,加锁(如Redis SETNX),从数据库加载数据后释放锁,其它请求等待或轮询

[2]逻辑过期

1、缓存永不过期,但存储数据时附加一个过期时间字段

2、发现数据逻辑过期时,触发异步更新

[3]热点数据加载

监控热点key,在接近过期时提前刷新缓存

3、缓存穿透

【1】定义

查询不存在的数据(如非法ID、恶意攻击),导致请求绕过缓存直接访问数据库

【2】原因

1、业务逻辑漏洞(如未校验参数合法性)

2、恶意攻击(如爬虫伪造不存在的ID)

【3】解决方案

[1]缓存空对象

对查询不到的数据,混存一个空值,并设置较短TTL

[2]布隆过滤器

在缓存层前加布隆过滤器,快速判断key是否存在:若布隆过滤器返回不存在,直接拒绝请求;若返回可能存在,继续查询缓存/数据库

[3]参数校验

对请求参数做合法性校验

4、对比总结

问题触发条件核心解决方案
缓存雪崩大量key同时失效差异化TTL、多级缓存、熔断降级
缓存击穿单个热点key失效互斥锁、逻辑过期、预加载
缓存穿透查询不存在的数据布隆过滤器、控制缓存、参数校验

5、最佳实践

1、监控与告警:实时监控缓存命中率、数据库QPS,设置阈值告警

2、压测模拟:通过模拟雪崩/击穿场景,验证解决方案的可靠性

3、组合策略:根据业务场景混合使用上述方案

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Redis Sentinel的使用方法

    Redis Sentinel的使用方法

    这篇文章主要介绍了Redis Sentinel的使用方法,帮助大家更好的理解和学习使用Redis数据库,感兴趣的朋友可以了解下
    2021-03-03
  • Redis Cluster集群动态扩容的实现

    Redis Cluster集群动态扩容的实现

    本文主要介绍了Redis Cluster集群动态扩容的实现,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07
  • 详解redis中的锁以及使用场景

    详解redis中的锁以及使用场景

    这篇文章主要介绍了详解redis中的锁以及使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Redis监控工具RedisInsight安装与使用

    Redis监控工具RedisInsight安装与使用

    这篇文章主要为大家介绍了Redis监控工具RedisInsight的安装步骤与使用方法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • Windows系统安装redis数据库

    Windows系统安装redis数据库

    这篇文章介绍了Windows系统安装redis数据库的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Redis如何实现数据库读写分离详解

    Redis如何实现数据库读写分离详解

    Redis的主从架构,能帮助我们实现读多,写少的情况,下面这篇文章主要给大家介绍了关于Redis如何实现数据库读写分离的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2018-03-03
  • redis的两种持久化方式RDB和AOF解读

    redis的两种持久化方式RDB和AOF解读

    Redis提供了RDB和AOF两种持久化方式,RDB是快照持久化,通过配置文件中的save指令开启和配置,可以设置触发快照的条件,AOF是日志持久化,每次写操作都会追加到AOF文件中,并可以通过配置文件设置持久化频率和重写策略,RDB和AOF可以结合使用,以提高数据的安全性和恢复效率
    2025-03-03
  • 浅析Redis如何保证数据不丢失

    浅析Redis如何保证数据不丢失

    Redis是一种Nosql类型的数据存储,全称Remote Dictionary Server,也就是远程字典服务器,本文主要来和大家讨论一下Redis如何保证数据不丢失,需要的可以参考下
    2024-02-02
  • Spring Boot 整合Redis 实现优惠卷秒杀 一人一单功能

    Spring Boot 整合Redis 实现优惠卷秒杀 一人一单功能

    这篇文章主要介绍了Spring Boot 整合Redis 实现优惠卷秒杀 一人一单,在分布式系统下,高并发的场景下,会出现此类库存超卖问题,本篇文章介绍了采用乐观锁来解决,需要的朋友可以参考下
    2022-09-09
  • redis中热key问题该如何解决

    redis中热key问题该如何解决

    这篇文章主要给大家介绍了关于redis中热key问题该如何解决的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05

最新评论