redis 缓存穿透,缓存击穿,缓存雪崩
虽然我们在使用 redis 缓存的时候非常的爽,它大大的提高了我们应用程序的性能和效率,尤其是数据查询方面,咱们不用直接去持久化的数据库中查询数据,而是到内存中查询数据即可
事物总是有两面的,用的爽的同时,也必须面对它带来的问题,就是数据一致性的问题,这个问题,是一个权衡利弊的问题,咱们接着看
redis 缓存和一些持久化的数据库配合使用的时候,会出现一些高可用的问题,如:
- 缓存穿透
- 缓存击穿
- 缓存雪崩
咱们能够解决上述问题,那就解决了一部分服务器高可用的问题
什么是缓存穿透
咱们先学习一部分,关于底层原理和实际源码分析,咱们之后再一起看
缓存穿透,就是用户想要查询一个数据,在 redis 中查询不到,即没有在缓存中命中,那么就会直接去持久化的 mysql 中进行查询,发现也没有这个数据,那么本次查询就失败了
当用户巨多的时候,查询缓存都没有查询到,那么这些全部都去查询持久化的 mysql 数据库,压力全部打到 mysql 上面,这就是缓存穿透
解决方案有一般有 2 种方式
- 使用布隆过滤器
- 缓存空的对象
使用布隆过滤器
布隆过滤器是一种数据结构,对所有可能查询到的参数都是以 hash 的方式存储,会先在控制层进行校验,不符合的话,则丢弃,这就避免了对底层存储系统的压力
布隆过滤器部署在 redis 的前面,去拦截数据,减少对 redis 的冲击,进而减小对 持久化层的冲击
缓存空的对象
缓存空对象,就是当我们在持久化的数据库中没有查询到我们期望的数据时,那么就返回一个空对象,并且将这个空对象缓存起来,再对其设置一个过期时间
那么之后再有访问这个对象的请求时,缓存直接访问空对象即可,这就可以保护持久化数据层,减少对他的冲击压力
通过上述缓存空对象的方式,貌似也能解决问题,但是使用持久下去,会发现 key 值对应的空对象越来越多,会出现下面 2 个问题
- 非常多的空对象被缓存起来,那么对应就很多的 key 占用 内存空间,占用资源,内存压力直线上升
- 如果空对象的过期时间到了,那么请求的压力还是会打到持久化数据库上面,这会影响数据的一致性业务
什么是缓存击穿
出现缓存击穿的情况是数据量太大,或者是缓存过期了
当某个 key 在过期的瞬间,有大量的请求这个 key 的数据,这种数据是热点数据,由于在缓存过期的瞬间,请求会同时访问到持久化的数据库来查询数据,并且会将数据会写到缓存中,此时就会导致数据库瞬间的压力过大,导致击穿
此处可以理解 击穿和穿透的区别:
击穿,是一个 key 非常热点,大量的访问都打在这个 key 上面,在 key 失效的瞬间,所有请求打在数据库上,就打出一个洞,击穿了
而穿透更多的是访问的数据不存在的情况,大量的请求访问的都是不存在的数据
缓存击穿的解决方案
- 将热点数据设置不过期,不设置过期时间,就不会出现热点 key 过期的瞬间造成问题
- 加上分布式锁,保证对于每一个 key ,同时只有一个服务进行访问,其他的服务没有获取到锁,就不能访问 redis 的这个 key,那么就需要等待获取锁
这种方式,锁的压力就非常大了,访问 redis 前先去访问锁,相当于锁给 redis 挡了一层
什么是缓存雪崩
缓存雪崩就是在某一个时间段,缓存集中过期,或者 redis 宕机的情况会出现
例如:
在某些热点活动中,会设置某些商品在一个固定的时间内过期,那么在 redis 里面,这个固定的时间点,大量的 key 过期,这就导致在这个时间段 缓存失效了,
且大量的请求数据都打在了持久化数据库上面了,这就很难受,在这种压力波峰下,压力全部打在持久化数据库上,这会造成持久化数据库宕机
上述的情况,key 集中过期问题还不是非常的痛,最痛的是 redis 宕机了,自然周期性的形成的波峰压力,咱们的持久化数据库还是能够顶得住压力的,偏偏是在 redis 异常宕机,一挂挂一片,这就很有可能将后方的持久化数据库全部打挂,这是毁灭性的压垮
缓存雪崩的解决方案:
- 将 redis 做成高可用的
搭建 redis 集群,异地多活,既然担心 redis 会挂,那么我们就多准备一些 redis ,做成主备,或者异地多活 - 限流降级
就是在缓存失效的时候,通过锁的方式来限制访问数据顺序,或者关掉一些不重要的服务,让资源和性能全力提供给我们的主要服务 - 做数据预热
数据预热就是咱们在正式要上线之前,咱们就先将需要访问的数据预先访问一次,这样就可以将大量要访问数据库的数据写到缓存中
这样就可以在即将发生的高并发访问数据前手动的触发并加载不同的 key ,且会设置不同的过期时间,主要是可以将缓存失效的事情均衡一些,这样就尽量避免掉大量的 key 集中过期的情况
redis 缓存穿透,缓存击穿,缓存雪崩相关推荐
- Redis 缓存穿透、击穿、雪崩现象及解决方案
前言 如何有效的理解并且区分 Reids 穿透.击穿和雪崩 缓存穿透 关键词:穿过 Redis 和数据库 当 Redis 和数据库中都没有我们想要的数据时,就需要考虑缓存穿透的问题了.下面这段逻辑大家 ...
- Redis应用问题解决(缓存穿透、击穿、雪崩、分布式锁)
Redis应用问题解决(缓存穿透.击穿.雪崩.分布式锁) 缓存穿透 问题描述 当系统中引入redis缓存后,一个请求进来后,会先从redis缓存中查询,缓存有就直接返回,缓存中没有就去db中查询,db ...
- Redis缓存穿透、击穿、雪崩、概念及解决办法
在生产环境中,会因为很多的原因造成访问请求绕过了缓存,都需要访问数据库持久层,虽然对Redsi缓存服务器不会造成影响,但是数据库的负载就会增大,使缓存的作用降低 一.缓存穿透 1.缓存穿透理解 缓 ...
- Redis 缓存穿透、击穿、雪崩 解决方法
目录 引言 一.缓存穿透 1. 缓存穿透的原理 2. 解决方法 2.1 布隆过滤器 2.2 缓存空对象 二.缓存击穿 1. 缓存击穿原理 2. 解决方法 2.1 设置热点数据永不过期 2.2 加互斥锁 ...
- 牛逼,三句话搞懂 Redis 缓存穿透、击穿、雪崩!
前言 如何有效的理解并且区分 Reids 穿透.击穿和雪崩之间的区别,一直以来都挺困扰我的.特别是穿透和击穿,过一段时间就稀里糊涂的分不清了. 为了有效的帮助笔者自己,以及拥有同样烦恼的朋友们区分这三 ...
- 缓存穿透、击穿、雪崩什么的傻傻分不清楚?看了这篇文后,我明白了
对于缓存,大家肯定都不陌生,不管是前端还是服务端开发,缓存几乎都是必不可少的优化方式之一.在实际生产环境中,缓存的使用规范也是一直备受重视的,如果使用的不好,很容易就遇到缓存击穿.雪崩等严重异常情景, ...
- 缓存穿透、击穿、雪崩
一.缓存穿透 缓存穿透是指缓存和数据库中均不存在目标数据,而用户不断发起请求,缓存也得不到更新,由此每次请求该数据都会到数据库.高并发量,就会对后端的 DB 系统造成很大压力.如查询 id 为&quo ...
- Redis_缓存穿透、击穿、雪崩
查询步骤图解 1.缓存穿透 什么是缓存穿透: 查询请求一直向数据库查询,导致数据库压力过大,甚至奔溃 本质原因:查询的数据既不在缓存中,也不在数据库中 此时会出现:程 ...
- Redis的穿透、击穿、雪崩问题
目录 Redis穿透 解决方法1:布隆过滤器 解决方法2:返回空对象 解决方法3:接口校验 Redis击穿 解决方案1:可以设置热点数据永远不过期 解决方案2:添加锁 Redis雪崩 解决方案1:加互 ...
- redis完整笔记总结-数据类型-事务与锁-集群-分布式锁-常见问题(缓存穿透、击穿、雪崩)
1. 数据类型 五大基本类型 String hash -> 类似map list set -> zset -> 基于set的有序集合 新增 bitmaps:其实就是string,主要 ...
最新文章
- 小米发力AI场景下的“快应用”,投百亿资源扶持开发者
- 拒收苹果超10万元赏金!程序员小哥找出iCloud账户漏洞后,发文直指苹果不够公开透明...
- dockerfile COPY ADD 命令
- Eclipse for Android 开发环境搭建及各种坑
- 算法练习day14——190402(贪心:切金条、做项目、会议室安排)
- mac 上搭建gitlabel_在Mac OS X中用Docker部署GitLab
- 计算机汉字的输入和编辑教案,计算机汉字录入教案
- 评论:IBM大型机能靠云计算挽回颓势吗?
- 8、Python车牌数据集自动生成及其图片叠加
- l298n使能端跳线帽_L298N 驱动模块的应用
- 3CDaemon FTP使用教程
- syslog (cactiez)
- html flash mp3播放器,网页实用最简单的flash mp3播放器代码-多样式
- 书到用时方恨少,一大波JS开发工具函数来了
- SSM框架,ajax实现登陆界面验证和登陆成功后页面跳转问题
- 许昌五女店考场考试安排
- ASEMI二极管A7参数,A7二极管规格书,A7二极管的封装
- 【蓝桥杯练习】100的阶乘有多少个约数?
- ActivePerl无法打开安装包
- Java回调函数理解和应用
热门文章
- pygame飞机大战用精灵组(sprite)的层(layer)编写(八)BOSS要花样,更多花样(附代码资源下载链接)
- Objective-C内存管理方式
- Linux查看防火墙状态和对外开放的端口状态
- 400元左右的蓝牙耳机推荐:NANK南卡和1more万魔蓝牙耳机哪个好?
- android api 完整通译之Contacts Provider (学习安卓必知的api,中英文对照)
- oracle pivot 列转行,Oracle 列转行函数pivot
- 步进梁式加热炉的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告
- 基于微信小程序的食谱大全系统
- VBA之正则表达式(10)-- 添加千分位(2/3)
- 什么是深浅拷贝,区别