Redis的缓存穿透、缓存雪崩和缓存击透

1.缓存穿透
什么是缓存穿透?查询一个数据库中一定不存在的数据。
在一些查询场景中,我们会选择使用缓存来存储查询结果,提高查询的效率。比如电商系统中的商品,第一次从数据库中查询商品信息,然后放入缓存;第二次将会直接从缓存中获取。
如果恶意攻击,进行大量不存在的商品查询,如果我们没有特殊处理,就会给数据库造成巨大的压力,严重的情况就会造成数据库崩溃(这就是我们要说的缓存穿透)。

解决方案:
针对不存在的数据,如果有缓存的场景,我们也需要将其缓存起来,并设置一个较短的过期时间。

2.缓存雪崩
什么是缓存雪崩?在某一个时间段,缓存集中过期。
缓存雪崩的问题就是在某一时刻,给数据库造成巨大的压力甚至导致数据库崩溃。

解决方案:
尽可能分散缓存的过期时间。比如缓存商品,不同分类按不同的缓存周期缓存;另外热门和冷门的商品,设置不同的缓存过期时间。

3.缓存击透
什么是缓存击透?一个高频访问的key,在即将过期的瞬间,大量并非集中访问这个key,直接请求数据库。

解决方案:
直接设置缓存永不过期。

猜你喜欢

转载自blog.csdn.net/weixin_39283212/article/details/89530769
今日推荐