如何解决缓存雪崩、缓存穿透和缓存击穿?

简介: 上一期视频,我跟大家聊了我对缓存雪崩、缓存穿透和缓存击穿的理解。那官方又是如何解释的呢?另外,往期面试题解析中配套的文档我已经准备好,想获得的可以在我的煮叶简介中找到。

需要面试文档可S我

上一期视频,我跟大家聊了我对缓存雪崩、缓存穿透和缓存击穿的理解。那官方又是如何解释的呢?另外,往期面试题解析中配套的文档我已经准备好,想获得的可以在我的煮叶简介中找到。

我们先来看缓存雪崩。

2.缓存雪崩

缓存雪崩:是指缓存同一时间大面积失效,后面数据查询时都查询数据库,数据查询的压力全部落到了数据库上,导致数据库短时间内承受大量的请求而down掉。如图所示:

f2081e5a9efd4f98e3ae885501255475.png

那如何预防缓存雪崩呢?我建议从以下四个方面来进行设置:

     1.缓存数据的过期时间设置为随机,防止同一时间出现大批数据过期的现象。

     2.将热点数据设置为永不过期。

     3.如果并发量不是特别高,可以加入队列或者锁。

     4.如果缓存数据库是分布式部署的,可以将热点的数据打散均匀分布到多个节点中。

2.缓存穿透

5d07a3b3b60aa1c779621bd65d9db129.png

缓存穿透:是指缓存和数据库中都没有的数据,导致所有的请求全都落到数据库上,并且是并发量较高,当然也有可能是恶意攻击,造成数据库短时间内承受大量请求而挂掉。

那如何预防缓存穿透呢?我建议从以下三个方面来进行设置:

1、给接口层增加校验,比如用户鉴权校验。

2、将空数据放到缓存中,设置key-null,同时设置短的缓存时间(如30秒),这样可以防止攻击用户反复用一个id暴力攻击

3、采用布隆过滤器,将所有可能存在的数据哈希存到一个足够大的 中,一些一定不存在的数据会被这个bitmap拦截掉,从而避免了对底层存储系统的查询压力。

4.缓存击穿

898c7730df93b78cdf1f45e1169d1834.png

缓存击穿:是指缓存中没有或者已经到期但是数据库中有的数据,这时由于并发用户特别多,同时在缓存中又没有读到数据,所以直接去数据库中取数据,引起数据库压力瞬间增大。和缓存雪崩不同的是,缓存击穿指并发查询同一条数据,缓存雪崩是不同数据都过期了,大面积数据都查询不到,从而查询数据库。

那如何预防缓存击穿呢?我建议从以下三个方面来进行设置:

1、设置热数据永不过期

2、使用 避免大量请求同时查询DB

3、做好熔断、降级,防止系统崩溃

以上就是我对缓存雪崩、缓存穿透和缓存击穿的解决方案,希望能够给小伙伴们提供参考的思路。

我是被编程耽误的文艺Tom,如果你还有其他不懂,可以关注我的主页介绍。如果我的面试解析对你有帮助,请分享给更多的人。关注我,面试不再难!

相关文章
|
1月前
|
存储 缓存 监控
缓存击穿、缓存穿透、缓存雪崩 3大问题,如何彻底解决?
【10月更文挑战第8天】在分布式系统中,缓存的使用极大地提高了系统的性能和响应速度。然而,缓存击穿、缓存穿透和缓存雪崩是三个常见的缓存相关问题,它们可能导致系统性能下降,甚至引发系统崩溃。本文将深入探讨这三个问题的成因、影响以及彻底的解决方案。
73 1
|
1月前
|
缓存 NoSQL 关系型数据库
redis和缓存及相关问题和解决办法 什么是缓存预热、缓存穿透、缓存雪崩、缓存击穿
本文深入探讨了Redis缓存的相关知识,包括缓存的概念、使用场景、可能出现的问题(缓存预热、缓存穿透、缓存雪崩、缓存击穿)及其解决方案。
173 0
redis和缓存及相关问题和解决办法 什么是缓存预热、缓存穿透、缓存雪崩、缓存击穿
|
6天前
|
缓存 NoSQL 关系型数据库
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
本文详解缓存雪崩、缓存穿透、缓存并发及缓存预热等问题,提供高可用解决方案,帮助你在大厂面试和实际工作中应对这些常见并发场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
|
19天前
|
存储 缓存 监控
利用 Redis 缓存特性避免缓存穿透的策略与方法
【10月更文挑战第23天】通过以上对利用 Redis 缓存特性避免缓存穿透的详细阐述,我们对这一策略有了更深入的理解。在实际应用中,我们需要根据具体情况灵活运用这些方法,并结合其他技术手段,共同保障系统的稳定和高效运行。同时,要不断关注 Redis 缓存特性的发展和变化,及时调整策略,以应对不断出现的新挑战。
52 10
|
19天前
|
缓存 监控 NoSQL
Redis 缓存穿透的检测方法与分析
【10月更文挑战第23天】通过以上对 Redis 缓存穿透检测方法的深入探讨,我们对如何及时发现和处理这一问题有了更全面的认识。在实际应用中,我们需要综合运用多种检测手段,并结合业务场景和实际情况进行分析,以确保能够准确、及时地检测到缓存穿透现象,并采取有效的措施加以解决。同时,要不断优化和改进检测方法,提高检测的准确性和效率,为系统的稳定运行提供有力保障。
47 5
|
19天前
|
缓存 监控 NoSQL
Redis 缓存穿透及其应对策略
【10月更文挑战第23天】通过以上对 Redis 缓存穿透的详细阐述,我们对这一问题有了更深入的理解。在实际应用中,我们需要根据具体情况综合运用多种方法来解决缓存穿透问题,以保障系统的稳定运行和高效性能。同时,要不断关注技术的发展和变化,及时调整策略,以应对不断出现的新挑战。
41 4
|
1月前
|
存储 缓存 NoSQL
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
60 4
|
1月前
|
消息中间件 缓存 NoSQL
大数据-49 Redis 缓存问题中 穿透、雪崩、击穿、数据不一致、HotKey、BigKey
大数据-49 Redis 缓存问题中 穿透、雪崩、击穿、数据不一致、HotKey、BigKey
51 2
|
1月前
|
缓存 NoSQL 关系型数据库
缓存穿透以及解决方案
缓存穿透以及解决方案
34 0
|
1月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(一)
数据的存储--Redis缓存存储(一)

热门文章

最新文章