这里写目录标题

  • 0. 前言
  • 1. 缓存雪崩
    • (1). 什么是缓存雪崩?
    • (2). 分析:
    • (3). 解决方案:
  • 2. 缓存击穿
    • (1). 什么是缓存击穿?
    • (2). 分析:
    • (3). 解决方案:
  • 3. 缓存穿透
    • (1). 什么是缓存穿透?
    • (2). 分析:
    • (3). 解决方案:

0. 前言

Redis作为目前使用最广泛的缓存,相信大家都不陌生。但是使用缓存并没有这么简单,还要考虑缓存雪崩,缓存击穿,缓存穿透的问题,什么是缓存雪崩,击穿,穿透呢。缓存击穿通常是由恶意攻击或者无意造成的;缓存并发是由设计不足造成的;缓存雪崩是由缓存同时失效造成的,三种问题都比较典型,也是难以防范和解决的。本节给出通用的解决方案,以供在缓存设计的过程中参考和使用。。

1. 缓存雪崩

(1). 什么是缓存雪崩?

当某一个时刻出现大规模的缓存失效的情况,那么就会导致大量的请求直接打在数据库上面,导致数据库压力巨大,如果在高并发的情况下,可能瞬间就会导致数据库宕机。这时候如果运维马上又重启数据库,马上又会有新的流量把数据库打死。这就是缓存雪崩。

(2). 分析:

造成缓存雪崩的关键在于在同一时间大规模的key失效。为什么会出现这个问题呢,有几种可能,第一种可能是Redis宕机,第二种可能是采用了相同的过期时间。

(3). 解决方案:

  1. 在原有的失效时间上加上一个随机值,比如1-5分钟随机。这样就避免了因为采用相同的过期时间导致的缓存雪崩。

  2. 如果真的发生了缓存雪崩,有没有什么兜底的措施?

    使用熔断机制。当流量到达一定的阈值时,就直接返回“系统拥挤”之类的提示,防止过多的请求打在数据库上。至少能保证一部分用户是可以正常使用,其他用户多刷新几次也能得到结果。

  3. 提高数据库的容灾能力,可以使用分库分表,读写分离的策略。

  4. 为了防止Redis宕机导致缓存雪崩的问题,可以搭建Redis集群,提高Redis的容灾性。

2. 缓存击穿

(1). 什么是缓存击穿?

其实跟缓存雪崩有点类似,缓存雪崩是大规模的key失效,而缓存击穿是一个热点的Key,有大并发集中对其进行访问,突然间这个Key失效了,导致大并发全部打在数据库上,导致数据库压力剧增。这种现象就叫做缓存击穿。


(2). 分析:

关键在于某个热点的key失效了,导致大并发集中打在数据库上。所以要从两个方面解决,第一是否可以考虑热点key不设置过期时间,第二是否可以考虑降低打在数据库上的请求数量。

(3). 解决方案:

  1. 上面说过了,如果业务允许的话,对于热点的key可以设置永不过期的key。
  2. 使用互斥锁。如果缓存失效的情况,只有拿到锁才可以查询数据库,降低了在同一时刻打在数据库上的请求,防止数据库打死。当然这样会导致系统的性能变差。

3. 缓存穿透

(1). 什么是缓存穿透?

我们使用Redis大部分情况都是通过Key查询对应的值,假如发送的请求传进来的key是不存在Redis中的,那么就查不到缓存,查不到缓存就会去数据库查询。假如有大量这样的请求,这些请求像“穿透”了缓存一样直接打在数据库上,这种现象就叫做缓存穿透。

(2). 分析:

关键在于在Redis查不到key值,这和缓存击穿有根本的区别,区别在于缓存穿透的情况是传进来的key在Redis中是不存在的。假如有黑客传进大量的不存在的key,那么大量的请求打在数据库上是很致命的问题,所以在日常开发中要对参数做好校验,一些非法的参数,不可能存在的key就直接返回错误提示,要对调用方保持这种“不信任”的心态。

(3). 解决方案:

  1. 把无效的Key存进Redis中。如果Redis查不到数据,数据库也查不到,我们把这个Key值保存进Redis,设置value=“null”,当下次再通过这个Key查询时就不需要再查询数据库。这种处理方式肯定是有问题的,假如传进来的这个不存在的Key值每次都是随机的,那存进Redis也没有意义。
  2. 使用布隆过滤器。布隆过滤器的作用是某个 key 不存在,那么就一定不存在,它说某个 key
    存在,那么很大可能是存在(存在一定的误判率)。于是我们可以在缓存之前再加一层布隆过滤器,在查询的时候先去布隆过滤器查询 key
    是否存在,如果不存在就直接返回。

总结
这三个问题在使用Redis的时候是肯定会遇到的,而且是非常致命性的问题,所以在日常开发中一定要注意,每次使用Redis时,都要对其保持严谨的态度。还有一个需要注意的是要做好熔断,一旦出现缓存雪崩,击穿,穿透这种情况,至少还有熔断机制保护数据库不会被打死。

缓存雪崩、缓存击穿、缓存穿透相关推荐

  1. 缓存雪崩、击穿、穿透解决方案

    用户的数据一般都是存储于数据库,数据库的数据是落在磁盘上的,磁盘的读写速度可以说是计算机里最慢的硬件了. 当用户的请求,都访问数据库的话,请求数量一上来,数据库很容易就奔溃的了,所以为了避免用户直接访 ...

  2. 老司机带你玩转面试(2):Redis 过期策略以及缓存雪崩、击穿、穿透

    前文回顾 建议前一篇文章没看过的同学先看下前面的文章: 「老司机带你玩转面试(1):缓存中间件 Redis 基础知识以及数据持久化」 过期策略 Redis 的过期策略都有哪些? 在聊这个问题之前,一定 ...

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

    Redis最常用使用的场景就是作为业务系统的缓存,既然是作为缓存,那么就不免会碰到缓存常见的问题,即雪崩.击穿与穿透,什么是缓存雪崩.击穿与穿透以及如何解决这几个问题呢?今天我们一起来探讨一下! 一. ...

  4. Redis 缓存雪崩、击穿、穿透

    Redis 缓存雪崩.击穿.穿透 文章目录 Redis 缓存雪崩.击穿.穿透 一.Redis基础 Redis基本数据类型.操作 二.面试相关问题 1.小伙子您好,看你简历上写了你项目里面用到了Redi ...

  5. 面试填坑之Redis无底洞(一、Redis缓存雪崩、击穿、穿透)

    Redis缓存雪崩.击穿.穿透 学习自大佬:https://blog.csdn.net/qq_35190492/article/details/102889333 https://www.cnblog ...

  6. redis缓存雪崩、击穿、穿透

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.redis缓存雪崩 二.redis缓存击穿 三.redis缓存穿透 前言 主要是介绍一下redis缓存雪崩.击穿. ...

  7. Redis中的缓存雪崩、击穿、穿透的原因以及解决办法

    缓存雪崩.击穿.穿透一旦发生,会导致大量的请求积压到数据库层.如果请求的并发量很大,就会导致数据库宕机或是故障,这就是很严重的生产事故了. 俗话说,知己知彼,百战不殆.了解了问题的成因,我们就能够在应 ...

  8. 关于缓存异常:缓存雪崩、击穿、穿透的解决方案

    关于缓存雪崩.击穿.穿透的解决方案 前言 缓存雪崩 缓存雪崩的原因 解决方案 缓存击穿 解决方案 缓存穿透 解决方案 布隆过滤器 布隆过滤器原理 布隆过滤器如何使用 在Java中使用布隆过滤器 前言 ...

  9. 如何解决缓存雪崩、击穿、穿透难题?

    缓存雪崩.缓存击穿和缓存穿透这三个问题是我们在使用redis做缓存的时候要面临的,一旦发生这三个问题,就会导致大量的请求都积压到了数据库层,有可能导致数据库宕机,进入导致整个系统不可用. 下边,具体看 ...

  10. Redis核心技术与实战-学习笔记(二十六):缓存雪崩、击穿、穿透

    一.缓存雪崩 缓存雪崩:大量应用请求无法在Redis缓存中进行处理,应用请求频繁访问数据库,导致数据库压力激增. 产生原因: 缓存中有大量数据同时过期,导致大量请求无法得到处理 数据保存在缓存中,并设 ...

最新文章

  1. Flask-uploads 简单使用
  2. 1. Action 实现 ModelDriven 接口后的运行流程
  3. C#和javascript的简单交互
  4. 4.4 高斯消元法的矩阵表示
  5. 在51单片机上使用递归的注意事项
  6. .net core @Html 自定义属性中包含特殊符号解决
  7. 两端“弱智”的HTML代码
  8. x86_64 x86 amd64 i386 i686 aarch64等词语含义
  9. Python——免费观看全网视频小程序
  10. 关于赛马的问题,25匹赛出前3名或者前5名
  11. 美团2020校招后台开发
  12. 2022第四届中国(山东)国际大健康产业博览会,即将开幕
  13. (附源码)计算机毕业设计SSM驾校预约考试管理系统
  14. 程序员北漂没钱整租,如何爱上合租?
  15. 【Windows】U 盘装系统,无法格式化所选磁盘分区[错误: 0x8004242d]
  16. python 重复图片_删除重复文件或图片(去重)的python代码
  17. linux虚拟机怎么退出pingdd,LINUX基本操作命令
  18. 打通BurpSuite与Python之间的任督二脉的插件—Burpy
  19. Log4j2研究之Filter
  20. 烽火fr2600怎么web登录_烽火R2600(R2640)路由器配置

热门文章

  1. 除了1682亿这个数字,天猫双11还有哪些细节值得关注?
  2. MEMS压力传感器助力家电产业智能化升级
  3. 意识形态舆情管控方案
  4. 干货:小微个人如何接入免费短信验证码
  5. laytpl与下拉框渲染数据,实现带输入功能的表格
  6. echarts 全局换肤 echarts根据系统颜色换肤,echarts自定义icon,echarts发光效果
  7. 随手记安全吗?个人感觉可以从以下三个方面去考虑
  8. Farthest Point Sampling(最远点采样)
  9. FLO 文件处理方式
  10. 【LinuxOS】IMG文件格式与ISO文件格式的区别