我的编程空间,编程开发者的网络收藏夹
学习永远不晚

redis缓存穿透的解决方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

redis缓存穿透的解决方法

这篇文章主要介绍redis缓存穿透的解决方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

缓存技术可以用来减轻数据库的压力,提升访问效率。目前在企业项目中对缓存也是越来越重视。但是缓存不是说随随便便加入项目就可以了。将缓存整合到项目中,这才是第一步。而缓存带来的穿透问题,进而导致的雪蹦问题都是我们迫切需要解决的问题。本篇文章将我平时项目中的解决方案分享给大家,以供参考。

一、缓存穿透的原理

缓存的正常使用如图:

redis缓存穿透的解决方法

如图所示,缓存的使用流程:

1、先从缓存中取数据,如果能取到,则直接返回数据给用户。这样不用访问数据库,减轻数据库的压力。

2、如果缓存中没有数据,就会访问数据库。

这里面就会存在一个BUG,如图:

redis缓存穿透的解决方法

如图,缓存就像是数据库的一道防火墙,将请求比较频繁的数据放到缓存中,从而减轻数据库的压力。 但是如果有人恶意攻击,那就很轻松的穿透你的缓存,将所有的压力都给数据库。比如上图,你缓存的key都是正整数,但是我偏偏使用负数作为key访问你的缓存,这样就会导致穿透缓存,将压力直接给数据库。

二、导致缓存穿透的原因

缓存穿透的问题,肯定是再大并发情况下。依此为前提,我们分析缓存穿透的原因如下:

1、恶意攻击,猜测你的key命名方式,然后估计使用一个你缓存中不会有的key进行访问。

2、第一次数据访问,这时缓存中还没有数据,则并发场景下,所有的请求都会压到数据库。

3、数据库的数据也是空,这样即使访问了数据库,也是获取不到数据,那么缓存中肯定也没有对应的数据。这样也会导致穿透。

三、解决缓存穿透

缓存穿透在于一步步规避穿透的原因,如图:

redis缓存穿透的解决方法

如上图所示,解决的步骤如下:

  • 1、再web服务器启动时,提前将有可能被频繁并发访问的数据写入缓存。—这样就规避大量的请求在第3步出现排队阻塞。

  • 2、规范key的命名,并且统一缓存查询和写入的入口。这样,在入口处,对key的规范进行检测。–这样保存恶意的key被拦截。

  • 3、Synchronized双重检测机制,这时我们就需要使用同步(Synchronized)机制,在同步代码块前查询一下缓存是否存在对应的key,然后同步代码块里面再次查询缓存里是否有要查询的key。  这样“双重检测”的目的,还是避免并发场景下导致的没有意义的数据库的访问(也是一种严格避免穿透的方案)。

    这一步会导致排队,但是第一步中我们说过,为了避免大量的排队,可以提前将可以预知的大量请求提前写入缓存。

  • 4、不管数据库中是否有数据,都在缓存中保存对应的key,值为空就行。–这样是为了避免数据库中没有这个数据,导致的平凡穿透缓存对数据库进行访问。

  • 5、第4步中的空值如果太多,也会导致内存耗尽。导致不必要的内存消耗。这样就要定期的清理空值的key。避免内存被恶意占满。导致正常的功能不能缓存数据。

以上是redis缓存穿透的解决方法的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

redis缓存穿透的解决方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis缓存击穿,雪崩,穿透解决方案

缓存穿透缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到存储层去查询,失去了缓存的意义。在流量大时,可能DB就挂掉了,要是有人利用不存在的key频繁攻
Redis缓存击穿,雪崩,穿透解决方案
2014-09-27

redis缓存穿透击穿雪崩解决方案

缓存常见问题及解决方案:缓存穿透:不存在于缓存和数据库中时,使用布隆过滤器或默认值避免无效查询。缓存击穿:高并发访问过期 key 时,使用互斥锁或永不过期热点数据解决。缓存雪崩:大量 key 同时过期时,设置不同过期时间、分流限流、缓存预热
redis缓存穿透击穿雪崩解决方案
2024-04-19

如何解决redis缓存穿透

redis 缓存穿透是指不存在于缓存中的键每次都会直接查询数据库,可采取以下措施解决:1. 使用布隆过滤器快速判断键是否存在;2. 使用空值缓存缓存不存在的值;3. 应用缓存穿透保护算法(漏斗算法、滑动窗口计数器)限制查询频率;4. 优化数
如何解决redis缓存穿透
2024-04-20

redis如何解决缓存穿透

redis通过以下方法解决缓存穿透:1. 设置默认值;2. 使用布隆过滤器;3. 使用空值缓存;4. 使用限流。这样,当查询不存在的键时,redis可以返回默认值、检查存在性或限制请求速率,从而避免后端数据库超载。Redis 如何解决缓存穿
redis如何解决缓存穿透
2024-04-19

redis缓存穿透如何解决

缓存穿透是指恶意用户不断查询数据库中不存在的数据,导致性能下降。解决方案包括:设置默认值使用布隆过滤器采用验证码机制限流慢查询日志分析加强数据校验Redis 缓存穿透解决方案什么是缓存穿透?缓存穿透是指恶意用户或爬虫不断查询数据库中不存
redis缓存穿透如何解决
2024-04-20

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

本篇内容介绍了“Redis缓存击穿、缓存穿透、缓存雪崩如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Redis缓存使用场景Redis
2023-07-05

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

缓存雪崩:比如给缓存中的key设置了统一的过期时间,而在过期时间点,有大量的请求进来,这个时候redis中没有用户请求的资源,所以所有的请求会全部拥到数据库,如果数据库有报警监测的话,可能会报一下警,然后数据库就挂掉了。如果这时候把数据重新起来,redis上还
2017-11-21

redis中缓存穿透击穿雪崩如何解决

这篇文章将为大家详细讲解有关redis中缓存穿透击穿雪崩如何解决,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一:前言设计一个缓存系统,不得不要考虑的问题就是:缓存穿透、缓存击穿与失效时的雪崩效应。二:缓
2023-06-15

redis缓存击穿和缓存穿透的区别

缓存击穿和缓存穿透的区别:缓存击穿:当大量并发请求访问未缓存的 key 时发生,导致数据库压力过大。缓存穿透:当恶意请求或爬虫频繁访问从未被缓存过的 key 时发生,导致不必要的数据库访问。Redis缓存击穿与缓存穿透的区别问题:缓存击穿
redis缓存击穿和缓存穿透的区别
2024-04-19

缓存穿透,缓存击穿,缓存雪崩解决方案分析

阅读本文大概需要 3.7 分钟。一、前言设计一个缓存系统,不得不要考虑的问题就是:缓存穿透、缓存击穿与失效时的雪崩效应。二、缓存穿透缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则
2023-06-05

Redis缓存击穿和穿透问题怎么解决

Redis缓存击穿和穿透是常见的性能问题,可以通过以下方法来解决:缓存击穿:当某个热点数据失效时,大量请求同时访问数据库,导致数据库压力突增。解决方法包括使用互斥锁避免并发请求穿透缓存、设置热点数据永不过期、使用布隆过滤器等方法。缓存穿透:
Redis缓存击穿和穿透问题怎么解决
2024-05-07

redis的缓存击穿和缓存穿透一样吗

否,redis缓存击穿和穿透是不同的概念。击穿是指并发访问未缓存的数据导致直接访问数据库;穿透是指恶意请求访问不存在的数据,导致缓存和数据库都未命中。解决方法分别是使用互斥锁和参数校验。Redis缓存击穿和缓存穿透问题: Redis缓存击
redis的缓存击穿和缓存穿透一样吗
2024-04-20

编程热搜

目录