redis 缓存血崩_redis缓存穿透和击穿缓存雪崩

redis 缓存血崩_redis缓存穿透和击穿缓存雪崩什么是Redis缓存雪崩、缓存穿透和缓存击穿?前言今天的分享主要是讲下这个 redis什么是缓存雪崩、穿透和击穿。这三个技术问题是我们平时开发工作中和面试过程中,必须要会的知识点,因为目前的互联网系统

什么是Redis缓存雪崩、缓存穿透和缓存击穿?

前言

今天的分享主要是讲下这个 redis

什么是缓存雪崩、穿透和击穿

这三个技术问题是我们平时开发工作中和面试过程中,必须要会的知识点,因为目前的互联网系统没有几个不需要用到缓存的,只要用到缓存的话,就需要掌握这三个技术问题。

基本上无论哪个老哥去大厂面试,都会被问题这几个问题,所以作为一个互联网开发程序员来说,这个几个技术问题大家是需要搞懂的。而解决这几个问题的方案,通常有布隆过滤器,还有分布式锁。

布隆过滤器是1970年的一项技术,距今也有50年了,之所以能够应用至今,说明这项技术还是挺优秀的,它也是谷歌搜索引擎所采用的一项技术,非常的火。这里就不展开说这个布隆过滤器了,后续会专门用一篇文章来讲这个布隆过滤器和分布式锁

接下来我们正式来说下什么是redis的缓存雪崩、穿透和击穿

补充一下:

定义:

终端研发部:牛逼,三句话搞懂 Redis 缓存穿透、击穿、雪崩!

缓存雪崩

我们首先看下这个正常的缓存流程是怎样的?如下图所示:

redis 缓存血崩_redis缓存穿透和击穿缓存雪崩

可以看到,首先这个用户访问这个某东,然后这个某东去访问这个 Redis,如果 Redis 有该访问数据,就会直接返回查缓存拿到的数据;如果 Redis 缓存没有查到该数据,就会去 MySql 数据库中查询,查询到有结果把从 MySql 中查到的数据同步至 Redis 缓存中去,同时会把这个查询到的结果返回回去。

这是一个简单的正常的缓存流程。 那么我们基于这个正常的缓存流程,来看下什么是缓存的雪崩。

首先给大家举个例子,就是在双十一的时候,在某东买东西,进入它的这个首页,由于是双十一,首页的访问量是非常大的,所以首页的很多数据是缓存在 redis 里面的。

假设首页数据存储在 redis 里的 100 个 key,设置的缓存失效时间是两个小时,当在双十一期间,购物超过两个小时之后,这个首页数据的 redis 缓存在这瞬间会全部失效,导致所有的请求都打到这个 MySql 数据库上,此时数据库的访问压力增大,造成这个 MySql 数据库响应不及时而挂掉,从而某东的首页就没办法继续对外提供服务了,然后东哥就特别不开心,把这次的技术负责人送去了非洲。

那么通过这个举例,我们来看下面这个图:

redis 缓存血崩_redis缓存穿透和击穿缓存雪崩

就是说用户访问某东,这个时候 redis 里面的 key 大量失效,导致这个某东直接访问数据库,把大量的请求都打到来数据库,这种现象就是缓存雪崩。简单来说就是 redis 缓存在同一时间大量失效,就像这个雪崩来了一样。

那么缓存雪崩它的解决方案有几种呢?下面来说下:

  • 设置这个缓存的失效时间,不让大量的 key 在同一时间失效,即在设置这个缓存的时候,可以将 key 的失效时间分散开
  • 我们部署 redis 一般是集群部署的,可以把这些热点的 key 放到不同的节点上去,让这些热点的 key 均匀的分布在不同的 redis 节点上
  • 还有就是比较暴力的方法,不设置这个缓存失效的时间,让 key 永不失效

缓存穿透

接下来我们再来介绍什么是缓存穿透。

还是举个例子:比如说某位老哥开发了一个网站,然后这个网站非常的受欢迎,某一天突然遭到了黑客疯狂的攻击,他的这个攻击手段就是采用这个缓存穿透的原理。

大家都知道通常情况下,数据库的主键是从0开始递增的,是没有负数的,那么这位黑客就利用这点,他不断的用 ID 小于零的参数发请求过来。这位老哥刚开始是把网站的所有数据放到了 redis 缓存里面去,但是黑客是用 ID 小于零的数来请求,redis 缓存里面并没有这个 ID 小于零的数据,这样 redis 就查不到这个结果,一旦 redis 查不到结果就会去数据库中查,那么所有请求都会打到数据库,而且会一直打到数据库中去,因为 redis 缓存这层根本拦截不到这样的数据。

redis 缓存直接被这种数据穿透了,直接穿透到数据库里面。同样我们来看下面这个图:

redis 缓存血崩_redis缓存穿透和击穿缓存雪崩

首先这个恶意用户访问某东,用 id=-1 的数据去请求,然后这个 id=-1 的数据在 redis 缓存里面没有查到,就到数据库里面查询,也没有查到该条数据,只能返回空数据给前端了。

这个恶意用户(黑客)用脚本不断的发这个数据去请求,直接穿透 redis 打到这个数据库上,这就是所谓的缓存穿透。 简单来说,缓存穿透就是指缓存和数据库中都没有这样的数据,一般出现这种情况都不是正常的用户在访问。

那么缓存穿透的解决方案有以下几点:

  • 请求如果穿透 redis,直接到数据库,那么数据库无论查出什么结果,都写回到 redis 缓存里面去,这样下次用同一个参数发来请求的时候,就直接被 redis 缓存拦截掉了,就不回打到数据库了
  • 对请求的参数做合法性校验
  • 比较直接、简单粗暴的方法,把这个 IP 拉黑
  • 最后是使用布隆过滤器,这是一个非常好的方式

缓存击穿

我们再来讲最后一个问题,就是缓存的击穿。

还是拿双十一来举例:东哥在双十一的时候,发话说想搞一个大活动,说想把自己20年前用的电脑拿出来拍卖,然后有巨多人对这个电脑感兴趣,于是东哥决定在双十一当天九点拍卖这台电脑,然后某东的开发程序员,把这台电脑数据放到了 redis 缓存里,即对应 redis 缓存里的一个 key。

拍卖的时候,大家热情都非常的高涨,持续拍卖了将近三个小时,还没有结束这场线上拍卖,但是这台电脑对应的 redis 缓存 key 的失效时间是三个半小时。 当大家拍卖到三个半小时的时候,这台电脑的缓存 key 突然失效了,导致这个大量的拍卖请求在 redis 里面查不到数据,从而这些大量请求就会直接打到数据库上,此时数据库的瞬间压力增大,造成响应不及时而挂掉。
这个时候呢,东哥看到自己的这台电脑还没拍卖出去,有点生气,于是把这个程序员送去了非洲。

同样我们也来看下面这个图:

redis 缓存血崩_redis缓存穿透和击穿缓存雪崩

用户访问某东,然后去 redis 请求某个拍卖秒杀商品,在缓存没有失效的时候,redis 可以把这个查询到的缓存 key 的结果返回回去,但是当这个缓存的 key 失效了,这个请求就会击穿这个 redis,直接打到数据库上。

这里大家注意的是,这里是某一个热点的 key,大量的用户请求不断的访问这个热点的 key,当这个热点的 key 突然失效,把请求都打到数据库上,这个过程就是叫做缓存击穿了。记住它是击穿某个一个非常热点的 key

那么这个缓存击穿的解决方案是:

  • 让这个热点 key 不过期,即不设置失效时间(不推荐)
  • 使用分布式锁,如果是单体应用的话使用互斥锁(分布式锁后续文章会讲)

总结

缓存雪崩:是指大量的缓存 key,在同一时间大量的失效。

缓存穿透:是指 redis 里没有请求想要的数据,直接穿过 redis 到数据库了。

缓存击穿:是指某个一个非常热点的 key,大量的用户去请求这个缓存热点 key,当这个缓存 key 突然失效的时候,这些请求都会打到数据库上。

本文转自 blog.csdn.net/lvlei1991

关于Redis的穿透、击穿、雪崩,解决方案重的解决方案:

终端研发部:Redis缓存穿透、击穿、雪崩,解决方案重磅来袭!

写在最后的话

大家看完有什么不懂的可以在下方留言讨论,也可以私信问我一般看到后我都会sigusoft的。最后觉得文章对你有帮助的话记得点个赞哦,点点不迷路

@终端研发部

每天都有新鲜的干货分享!

激活谷谷主为您准备了激活教程,为节约您的时间请移步至置顶文章:https://sigusoft.com/99576.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。 文章由激活谷谷主-小谷整理,转载请注明出处:https://sigusoft.com/10449.html

(0)
上一篇 2024年 5月 12日 上午11:21
下一篇 2024年 5月 12日 下午12:06

相关推荐

  • cpp socket编程

    cpp socket编程大家都是知道在黑客网络攻防中,熟悉网络通信原理很重要,之前我也写过相关文章,只要了解通信过程,就可以利用过程中存在的漏洞进行攻防,那么在实现攻防的时候,作为一名黑客一定要学会网络编程,而网络编程中很重要的一个环节就是”Socket”的学习和使用!今天就以本篇

    激活谷笔记 2024年 5月 18日
  • l298n芯片封装_l298芯片的接线方法

    l298n芯片封装_l298芯片的接线方法L298N的接线和详细使用方法文章说明:名词概念(为了方便易懂,我就通俗的表达):逻辑电压:控制板子执行程序的电压。驱动电压:输出口AB的电压。逻辑电流:驱动板执行程序的电流。驱动电流:输出口AB的电流。本人调试此款L298N,只调试过3

    2024年 5月 21日
  • vision怎么读_vision牌子中文名

    vision怎么读_vision牌子中文名vision是什么意思,vision怎么读,vision翻译为:视力,视觉;美景,绝提示:点击例句中的单词,就可以看到词义解释 The

    激活谷笔记 2024年 5月 16日
  • Datagrip激活2024.1.3(DataGrip 2024.1.3)

    Datagrip激活2024.1.3(DataGrip 2024.1.3)

    激活谷笔记 2024年 6月 7日
  • Goland激活2024.1.2(GoLand 2024.1 中文激活成功教程版)

    Goland激活2024.1.2(GoLand 2024.1 中文激活成功教程版)

    2024年 6月 7日
  • topsis全称_top的全称

    topsis全称_top的全称topsis综合评价法【导读】topsis综合评价法即根据有限个评价对象与理想化目标的接近程度进行排序的方法,是在现有的对象中进行相对优劣的评价,是一种逼近于理想解的排序法。topsis综合评价法topsis综合

    2024年 5月 26日
  • ddds值是什么意思_抗生素ddds值是什么意思

    ddds值是什么意思_抗生素ddds值是什么意思抗菌药物DDD值速查表抗菌药物DDD值速查表数据依据:ATC/DDD Index,抗菌药物临床应用监测网附:DDD:限定日剂量。用于主要治疗目的的成人的药物平均日剂量。DDDs:用药频度。DDDs=该药年销售总量(g)/该药的DDD值。DDDs可反映不同年度的用药动态和用药结构,

    2024年 5月 30日
  • Ubuntu安装教程u盘_u盘windows10安装教程

    Ubuntu安装教程u盘_u盘windows10安装教程U盘安装系统实用全面教程(单系统(windows10,windows7,ubuntu),双系统(ubuntu+windows))综述学会U盘安装操作系统是一件可以极大提升自己的一件事情。除硬件以外的问题都可以通过重装系统进行解决。U盘安装操作系统,有这一篇就够啦!这篇文章主要讲如下内容:1

    2024年 5月 12日
  • 串口助手发送的数据格式不对怎么解决_串口助手发送的数据格式不对怎么解决呢

    串口助手发送的数据格式不对怎么解决_串口助手发送的数据格式不对怎么解决呢如何使用串口调试助手(调试串口)?智联物联串口网络数据调试助手V1.5是一款非常好用的调试工具,串口网络数据调试助手V1.5显示流畅,不容易丢数据,支持字符串和十六进制方式显示,和加时间戳分数据包显示。串口网络数据调试助手V1.5串口网络数据调试助手V1.5特点1、显示流畅,中文显示无乱码,

    2024年 5月 20日
  • 解析offsetHeight,clientHeight,scrollHeight之间的区别

    解析offsetHeight,clientHeight,scrollHeight之间的区别这篇文章主要是对offsetHeight,clientHeight,scrollHeight之间的区别进行了详细介绍,需要的朋友可以过来参考下,希望对大家有所帮助

    激活谷笔记 2024年 3月 22日
  • spider软件安全吗_spider 软件

    spider软件安全吗_spider 软件新的恶意软件“Spider”,给受害者96小时的付款期限原标题:新的恶意软件“Spider”,给受害者96小时的付款期限安全研究人员发现新的勒索软件,该软件将会加密受害者的软件,并给受害者96小时的最后支付期限。Netskope威胁研究实验室的专家们于12月10日发现了这个具有“中等规模”的勒索

    激活谷笔记 2024年 5月 29日
  • DataSpell激活2024.1.1(IDEA 2024.1 最新激活码,激活成功教程版安装教程)

    DataSpell激活2024.1.1(IDEA 2024.1 最新激活码,激活成功教程版安装教程)

    2024年 6月 7日
关注微信