IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 浅谈Redis的缓存击穿、缓存雪崩和缓存穿透 -> 正文阅读

[大数据]浅谈Redis的缓存击穿、缓存雪崩和缓存穿透

? ? ? ? Redis缓存的出现,可以极大的解决了我们项目中遇到的一些查询慢问题,但是用到Redis作为缓存的时候,我们不得不考虑缓存击穿、缓存雪崩和缓存穿透这些问题,那么下面就来浅谈一些这些问题的出现情况和解决方案。

一、缓存击穿

? ? ? ? 缓存击穿出现的情况是,一个请求绕过了缓存,直接请求数据库。比如故意拿一个不存在的key去请求缓存,缓存不存在,则直接请求数据库。如果是这样,那么缓存就失效了。

? ? ? ? 解决方案:

? ? ? ? 1、如果缓存不存在,数据库也不存在,则直接设置很短的失效时间,给该key设置一个null值,那么当在失效时间到达之前,不会一直请求数据库了。当有新数据来的时候,可以及时更新缓存。

? ? ? ? 2、利用布隆过滤器进行拦截。原理是,将所用到的key提前存好到布隆过滤器中,当请求缓存或者数据库时,先到布隆过滤器看看该key是否存在,如果存在则只需操作,否则不执行。这种场景适合于key数量变动不大的情况下。

二、缓存雪崩

? ? ? ? 缓存雪崩的意思就是大量的缓存key在同一时间失效,此时大量请求直接请求数据库,导致数据量承受大量请求。

????????解决方案:

? ? ? ? 1、对不同的key设置不同的失效时间,这样就不会大量key同时失效。

三、缓存击穿

? ? ? ? 缓存击穿是指当大量请求同时请一个key,此时该key刚好失效了,此时会有大量请求到达数据库,导致数据库承受大量请求。

? ? ? ? 解决方案:

? ? ? ? 1、设置热点数据不过期,这样就不会有失效的问题了。

? ? ? ? 2、利用互斥锁锁住该条数据,当第一个请求到达时,执行更新缓存操作,其他请求先等待,当第一个请求更新成功缓存,那么其他请求直接从缓存获取数据,这样就不会再次请求数据库了。

四、总结

? ? ? ? 每天总结一点,每天进步一点,这样当你在项目中用到之前学到的知识时,能够想到这些场景,你就能避免这些问题,这样你写的代码才能更加健壮。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-16 17:44:46  更:2021-12-16 17:47:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 12:07:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码