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)

相关推荐
倔强的石头_5 小时前
WorkBuddy 上手实战:打造一个可用的本地 AI 工作台
后端
kyriewen7 小时前
面试官问你:“AI 能写 80% 的代码了,公司为什么还需要你?”
前端·javascript·面试
冬奇Lab8 小时前
每日一个开源项目(第141篇):hiring-agent - HackerRank 开源了他们的简历评分系统,你的简历能得几分?
人工智能·面试·开源
苍何10 小时前
Coding 真有质的飞跃?实测下豆包seed 2.1 pro
后端
苍何10 小时前
试了下腾讯 Marvis,回不去了...
后端
caibixyy10 小时前
springboot+langchain4j 实战 Day14——工具嵌入多 Agent(Tool-Equipped Multi-Agent)
后端
caibixyy10 小时前
springboot+langchain4j 实战 Day13 多 Agent 协作(Router + 子 Agent 分流)
后端
飘尘10 小时前
前端转全栈(Java 后端)必须要知道的:开发中的锁机制与分布式并发控制
前端·后端·全栈
苍何10 小时前
清华团队做了个具身智能大脑,有点东西!
后端