缓存雪崩 & 缓存穿透

本文介绍了缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。针对缓存雪崩,提出了设置主从架构、使用Sentinel、设置过期时间随机化以及使用锁或队列等策略。缓存穿透的解决方法包括使用布隆过滤器和空对象缓存。对于缓存击穿,提出了设置热点数据不过期和使用互斥锁的方法。还讨论了缓存预热、更新、降级及双写一致性问题的处理方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

缓存雪崩 & 缓存穿透

1233356-0601b23b20de2434.png

缓存雪崩 & 缓存穿透.png

缓存流程

1.参数传入对象主键ID

2.根据key从缓存中获取对象

3.如果对象不为空,直接返回

4.如果对象为空,查询数据库

5.如果从数据库查询出的对象不为空,则放入缓存(设定过期时间)

缓存雪崩

如果我们的缓存挂掉了,这意味着我们的全部请求都跑去数据库了。

如果缓存数据设置的过期时间是相同的,并且Redis恰好将这部分数据全部删掉。

这就会导致在这段时间内,这些缓存同时失效,全部请求到数据库中。

缓存挂掉解决方案

  • 事发前

    • 主从架构+Sentinel
    • Cluster
    • 分布式缓存架构
    • 设置过期标志更新缓存
    • 使用锁或队列
    • 二级缓存
  • 事发中

    • 设置本地缓存(ehcache)+限流(hystrix)
  • 事发后

    • 缓存持久化
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI天才研究院

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值