Redis四大经典缓存问题

一、缓存穿透:查不存在的数据,绕过缓存直打DB

现象

查询数据库没有的数据,缓存无key → 每次都查DB,DB压力暴增(恶意空参攻击)。

解决方案

  1. 缓存空值:DB查不到,Redis存入key:null,过期短时间(5min)

  2. 布隆过滤器 BloomFilter:所有合法key预加载过滤器,不存在直接返回,不查Redis、DB

  3. 参数校验:非法ID直接拦截

二、缓存击穿:热点key过期瞬间,大量请求打DB

现象

高并发热点key(秒杀商品)刚好过期,海量请求同时穿透到数据库。

方案

  1. 互斥锁(Redisson分布式锁):缓存失效时,只有一个线程查DB+写缓存,其余等待重试

  2. 永不过期(逻辑过期):key不设expire,单独起异步线程定时刷新缓存

  3. 过期时间加随机值,打散过期时间

三、缓存雪崩:大量key同一时间集体过期 + Redis宕机

现象

大批量缓存同时失效,流量全部涌入DB,数据库崩溃。

方案

  1. 过期时间加随机偏移值:expireTime = base + random(1~30min),错开过期

  2. Redis集群高可用:主从+哨兵/Cluster,避免单点宕机

  3. 限流降级:缓存失效后熔断,直接返回兜底数据,不再查库

  4. 多级缓存:本地Caffeine + Redis二级缓存

四、缓存和DB双写不一致(更新难题)

问题:更新数据库后缓存不同步,脏数据

主流策略

  1. 先更DB,再删缓存(推荐)

    更新数据库 → 删除Redis缓存,下次查询自动加载新数据

    缺陷:极短窗口期并发脏读,可加分布式锁优化

  2. 延时双删:更新DB→删缓存→休眠几百ms→再删一次缓存

  3. 消息队列异步更新缓存(高并发项目)

五、补充高频问题

  1. Redis淘汰策略(内存满了删key)

• volatile-lru:过期key优先LRU淘汰(默认)

• allkeys-lru:所有key LRU淘汰

• volatile-ttl:删剩余过期时间最短

• noeviction:内存满直接报错(不删数据)

  1. 缓存预热

项目启动提前加载热点数据进Redis,避免上线瞬间大量查DB。

  1. 分布式锁选型

• Redisson(推荐,解决死锁、锁续期)

• Redis原生SETNX+EXPIRE(原子命令 SET key val NX EX 30)

相关推荐
超梦dasgg1 小时前
Redisson解锁失败,WatchDog会不会一直续期下去?
java·redis
Chase_______1 小时前
【Java基础 | 11】异常处理进阶:throw、throws、自定义异常与异常链讲清楚
java·开发语言·python
cheems95271 小时前
[Redis] redis常见命令和String字符串解析
数据库·redis·缓存
DFT计算杂谈1 小时前
VASP 磁性结构可视化:一键生成完美 VESTA / MCIF
java·前端·css·html·css3
砍材农夫2 小时前
物联网实战:Spring Boot MQTT | 模拟器Paho客户端拆解核心点
java·javascript·网络·spring boot·后端·物联网
weixin_539446782 小时前
使用Java HttpServletResponse和JavaScript Fetch下载文件
java·javascript·python
掘金者阿豪2 小时前
用 Codex 的不会还不知道这些开源项目提效吧?
后端
我登哥MVP2 小时前
Spring Boot 从“会用”到“精通”:自动装配原理
java·spring boot·后端·spring·tomcat·maven·intellij-idea
小的~~2 小时前
Java线程及线程池的相关的问题
java·开发语言·多线程