| |
|
开发:
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、利用互斥锁锁住该条数据,当第一个请求到达时,执行更新缓存操作,其他请求先等待,当第一个请求更新成功缓存,那么其他请求直接从缓存获取数据,这样就不会再次请求数据库了。 四、总结 ? ? ? ? 每天总结一点,每天进步一点,这样当你在项目中用到之前学到的知识时,能够想到这些场景,你就能避免这些问题,这样你写的代码才能更加健壮。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |