Redis(缓存穿透、缓存击穿、缓存雪崩)

缓存穿透

缓存穿透:查询一个不存在的数据,mysql查询不到数据也不会直接写入缓存,就会导致每次请求都查数据库

解决方案一:缓存空数据,查询返回的数据为空,仍把这个空结果进行缓存

优点:简单

缺点:消耗内存,可能会发生不一致的问题

解决方案二:布隆过滤器,使用redisson中的布隆过滤器来解决。

缓存击穿

缓存击穿:给某个key设置了过期时间,当key过期的时候,恰好这个时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把数据库压垮

解决方案一:互斥锁

解决方案二:逻辑过期

缓存雪崩

缓存雪崩:在同一时段大量的缓存key同时失效后者redis服务宕机,导致大量请求到达数据库,带来巨大压力

解决方案:

    • 给不同的key的TTL添加随机值
    • 利用Redis集群提高服务的可用性 哨兵模式、集群模式
    • 给缓存业务添加降级限流策略 ngxin或spring cloud gateway
    • 给业务添加多级缓存 Guava或Caffeine
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

贰零贰伍的学习历程

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

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

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

打赏作者

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

抵扣说明:

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

余额充值