Redis - 什么是缓存穿透、击穿、雪崩?如何解决

Redis - 什么是缓存穿透、击穿、雪崩?如何解决_有机后浪的博客-CSDN博客

缓存与后端系统

通常后端会采用Mysql等磁盘数据库,可以持久化但是访问慢,高并发时性能差,需要设置Nosql内存型数据库缓存:Redis等

在这里插入图片描述

但缓存可能出现:缓存穿透、缓存击穿、缓存雪崩等问题


认识缓存穿透、击穿、雪崩

  1. 热点key:常被访问的key,如热搜榜

  2. 缓存穿透

查找数据的顺序是:先查找缓存,再查找数据库

当查找一个数据时,缓存没有都会请求数据库,当查找的数据为热点key,高并发时缓存就起不到作用,会压垮数据库
如果黑客利用这个不存在的key进行攻击可能压垮数据库

  1. 缓存击穿

缓存中没有数据但数据库里有(例如缓存过期),会进入后端访问数据库并回设到缓存,高并发的请求key,会压垮数据库

  1. 缓存雪崩

当缓存服务器重启或者缓存短时间内大量失效,高并发时,引起数据库压力过大甚至宕机。

和缓存击穿不同的是, 缓存击穿指并发查同一条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从而查数据库


缓存穿透解决方案

缓存穿透是查询不存在的数据时会访问数据库

有两种方法:

  • 布隆过滤器:将数据库中的数据哈希映射到bitmap(0、1表示存在、不存在),查询时先访问bitmap,查询不存在的数据就会被bitmap拦截,就不用进入数据库查询

在这里插入图片描述

  • 返回空值给缓存:当查询不存在数据访问数据库返回值为空,仍然将空值进行缓存(Redis中value为空值会被回收,可以设置empty字符串等),当然插入值时要替代掉空值

在这里插入图片描述


缓存击穿解决方案

缓存击穿是数据缓存没有而数据库有,查询时需要进入数据库查询,高并发时会压垮数据库

有两种解决方案:

  • 设置热点key永不过期
  • 加互斥锁(mutex key)

互斥锁:在缓存失效的时候(判断拿出来的值为空),第1个进入的线程,获取锁并从数据库去取数据,没释放锁之前,其他并行进入的线程会等待,再重新去缓存取数据

Redis:使用setnx操作去set一个mutex key,当操作返回成功时,再进行load db的操作并回设缓存;否则,就重试整个get缓存的方法。

setnx key value:当key不存在时才设置值,key存在不操作。setnx可以实现互斥锁

在这里插入图片描述

通过互斥锁,高并发也仅查询一次数据库


缓存雪崩解决方案

缓存雪崩是缓存服务器重启或者大量缓存失效,引起数据库压力过大

这里的问题是多个key缓存,有两种方案:

  • 尽量设置缓存失效时间均匀分布,别在短时间内大量缓存过期

  • 考虑用加锁队列的方式来保证不会有大量的线程对数据库一次性进行读写,从而避免失效时大量的并发请求数据库
    (在高并发下线程阻塞,用户体验差)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
缓存穿透、缓存击穿和缓存雪崩是常见的缓存问题,下面是关于Redis缓存穿透、缓存击穿和缓存雪崩的介绍: 1. 缓存穿透缓存穿透是指当一个请求查询一个不存在于缓存中的数据时,由于缓存无法命中,请求会直接访问数据库。这种情况下,如果有大量的请求查询不存在的数据,会导致数据库压力过大,影响系统性能。 2. 缓存击穿: 缓存击穿是指当一个热点数据的缓存过期或失效时,大量的请求同时访问该数据,导致缓存无法命中,请求会直接访问数据库。这种情况下,数据库会承受巨大的压力,可能导致数据库崩溃。 3. 缓存雪崩: 缓存雪崩是指当缓存中的大量数据同时过期或失效时,大量的请求会直接访问数据库,导致数据库压力剧增,性能下降甚至系统崩溃。缓存雪崩通常是由于缓存服务器故障、缓存设置不合理或者缓存数据过期时间设置不当等原因引起的。 为了避免缓存穿透、缓存击穿和缓存雪崩问题,可以采取以下措施: - 缓存穿透:可以在应用层对查询的数据进行校验,如果数据不存在,则不进行缓存操作,避免大量无效的请求访问数据库。 - 缓存击穿:可以互斥锁或分布式锁来保护热点数据的问,当缓存失效时,只允许一个请求访问数据库并更新缓存,其他请求等待缓存更新完成后再从缓存中获取数据。 - 缓存雪崩:可以采用多级缓存、缓存预热、设置合理的缓存过期时间等策略来避免大量缓存同时失效,保证系统的稳定性和性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值