解决缓存穿透

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

方法二:如果一个查询返回的数据为空(不管数据不存在还是系统故障),我们仍然把这个空结果进行缓存,但它的过期时间会很短,最长不超过五分钟。

解决缓存击穿

key可能会在某些时间点被超高并发地访问,是一种非常“热点”的数据。这个时候,需要考虑一个问题:缓存被“击穿”的问题。

使用互斥锁(mutex key)

业界比较常用的做法,是使用mutex。简单地来说,就是在缓存失效的时候(判断拿出来的值为空),不是立即去load db,而是先使用缓存工具的某些带成功操作返回值的操作(比如Redis的SETNX或者Memcache的ADD)去set一个mutex key,当操作返回成功时,再进行load db的操作并回设缓存;否则,就重试整个get缓存的方法。

SETNX,是「SET if Not eXists」的缩写,也就是只有不存在的时候才设置,可以利用它来实现锁的效果。

解决缓存雪崩

与缓存击穿的区别在于这里针对很多key缓存,前者则是某一个key。

缓存正常从Redis中获取,示意图如下:

缓存失效瞬间示意图如下:

缓存失效时的雪崩效应对底层系统的冲击非常可怕!大多数系统设计者

考虑用加锁或者

队列的方式保证来保证不会有大量的线程对数据库一次性进行读写,从而避免失效时大量的并发请求落到底层存储系统上。

还有一个简单方案就时讲缓存失效时间分散开,比如我们可以在原有的失效时间基础上增加一个随机值,比如1-5分钟随机,这样每一个缓存的过期时间的重复率就会降低,就很难引发集体失效的事件。

加锁排队只是为了减轻数据库的压力,并没有提高系统吞吐量。

假设在高并发下,缓存重建期间key是锁着的,这是过来1000个请求999个都在阻塞的。同样会导致用户等待超时,这是个治标不治本的方法!

加锁排队的解决方式分布式环境的并发问题,有可能还要解决分布式锁的问题;线程还会被阻塞,用户体验很差!因此,在真正的高并发场景下很少使用!

Redis缓存穿透 缓存击穿 缓存雪崩原因及其解决方案相关推荐

  1. Redis 缓存穿透、击穿、雪崩现象及解决方案

    前言 如何有效的理解并且区分 Reids 穿透.击穿和雪崩 缓存穿透 关键词:穿过 Redis 和数据库 当 Redis 和数据库中都没有我们想要的数据时,就需要考虑缓存穿透的问题了.下面这段逻辑大家 ...

  2. mysql数据库击穿_缓存穿透、击穿、雪崩区别和解决方案

    自强学堂 文中的cache指缓存,比如redis,db指数据库,比如mysql. 一.缓存的三种模式 这里主要指的是应用代码对 cache 和 db 中数据的维护方式. 1.1 应用代码同时更新 ca ...

  3. Redis应用问题解决(缓存穿透、击穿、雪崩、分布式锁)

    Redis应用问题解决(缓存穿透.击穿.雪崩.分布式锁) 缓存穿透 问题描述 当系统中引入redis缓存后,一个请求进来后,会先从redis缓存中查询,缓存有就直接返回,缓存中没有就去db中查询,db ...

  4. Redis缓存穿透、击穿、雪崩、概念及解决办法

    在生产环境中,会因为很多的原因造成访问请求绕过了缓存,都需要访问数据库持久层,虽然对Redsi缓存服务器不会造成影响,但是数据库的负载就会增大,使缓存的作用降低 一.缓存穿透 1.缓存穿透理解   缓 ...

  5. Redis 缓存穿透、击穿、雪崩 解决方法

    目录 引言 一.缓存穿透 1. 缓存穿透的原理 2. 解决方法 2.1 布隆过滤器 2.2 缓存空对象 二.缓存击穿 1. 缓存击穿原理 2. 解决方法 2.1 设置热点数据永不过期 2.2 加互斥锁 ...

  6. 牛逼,三句话搞懂 Redis 缓存穿透、击穿、雪崩!

    前言 如何有效的理解并且区分 Reids 穿透.击穿和雪崩之间的区别,一直以来都挺困扰我的.特别是穿透和击穿,过一段时间就稀里糊涂的分不清了. 为了有效的帮助笔者自己,以及拥有同样烦恼的朋友们区分这三 ...

  7. 缓存穿透、击穿、雪崩什么的傻傻分不清楚?看了这篇文后,我明白了

    对于缓存,大家肯定都不陌生,不管是前端还是服务端开发,缓存几乎都是必不可少的优化方式之一.在实际生产环境中,缓存的使用规范也是一直备受重视的,如果使用的不好,很容易就遇到缓存击穿.雪崩等严重异常情景, ...

  8. 缓存穿透、击穿、雪崩

    一.缓存穿透 缓存穿透是指缓存和数据库中均不存在目标数据,而用户不断发起请求,缓存也得不到更新,由此每次请求该数据都会到数据库.高并发量,就会对后端的 DB 系统造成很大压力.如查询 id 为&quo ...

  9. Redis_缓存穿透、击穿、雪崩

    查询步骤图解 1.缓存穿透 什么是缓存穿透:          查询请求一直向数据库查询,导致数据库压力过大,甚至奔溃         本质原因:查询的数据既不在缓存中,也不在数据库中 此时会出现:程 ...

  10. Redis的穿透、击穿、雪崩问题

    目录 Redis穿透 解决方法1:布隆过滤器 解决方法2:返回空对象 解决方法3:接口校验 Redis击穿 解决方案1:可以设置热点数据永远不过期 解决方案2:添加锁 Redis雪崩 解决方案1:加互 ...

最新文章

  1. 为循环的repeater的第一行加个样式
  2. 如何评估序列推荐模型?
  3. 使用SQLQuery
  4. 基于JavaFX的SimpleDateFormat演示程序
  5. web.config 指定的默认页失效
  6. html引入vue不兼容ie11,关于vue.js:iview按需引入ie11不兼容报无效字符问题解决
  7. JumpServer 开源堡垒机 快速部署
  8. CentOS7 系统升级,删除centos7开机界面多余选,升级至最新的内核
  9. 【Android Studio安装部署系列】十九、Android studio使用SVN
  10. 10个Jquery幻灯片插件教程
  11. 【Python爬虫实战】微信爬虫
  12. openssl 加盐_nodejs-md5加盐到解密比对
  13. ONLYOFFICE权限开发之二
  14. openssl1.1.1下载地址
  15. 中恒建模助手bim软件中的建筑给排水设计,给水系统和中水系统什么意思?
  16. java导出excel合并单元格_Java 导出Excel 合并Excel单元格
  17. CleanMyMac X是干嘛的?及最新版功能介绍
  18. 一年纯手工打造的Java老A上册开始预售了
  19. 使用teensy 2.0++ 开发板模拟U盘
  20. STM32学习笔记——GPIO,点灯之路第一步

热门文章

  1. mongo-connector导入数据到Elasticsearch
  2. Linux服务器开发之:stat(),fstat(),lstat()详细介绍+案例演示
  3. 类模板,多种类型的类模板,自定义类模板,类模板的默认类型,数组的模板实现,友元和类模板,友元函数,类模板与静态变量,类模板与普通类之间互相继承,类模板作为模板参数,类嵌套,类模板嵌套,类包装器
  4. 处理字符串_5_字符串里过滤不需要的字符
  5. 单例销毁_【PHP设计模式】单例模式
  6. 深入浅出设计模式原则之里氏代换原则(Liskov Substitution Principle)
  7. SSD框架训练自己的数据集
  8. cmd SETLOCAL使用介绍
  9. cv2.bitwise_not(主要讲这个)
  10. 『原创』+『参考』使用WMI在C#下获取U盘的永久不变的物理序列号