| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> 十分钟彻底掌握缓存击穿、缓存穿透、缓存雪崩 -> 正文阅读 |
|
[大数据]十分钟彻底掌握缓存击穿、缓存穿透、缓存雪崩 |
作者:recommend-item-box type_blog clearfix |
大家好,我是老三,刷题刷烦了…… 写篇文章缓一下,分享一下老八股: 在了解这三大问题之前,我们要理解,常用的分布式缓存Redis单机并发量能达到万级,常用的关系型数据库MySQL一般并发量是千级,他们支持的并发量可能差十倍,所以要尽可能把流量拦截在缓存层。 为什么呢?就像是大湖里多排点水,就可能把小河道冲垮,不知道你听过没——长江之水天上来,白洋淀里把不住。 缓存击穿什么是缓存击穿先从缓存击穿开始。 缓存击穿: 一个并发访问量比较大的key在某个时间过期,导致所有的请求直接打在DB上。 缓存击穿会增大数据库的负载,我们看看怎么缓解。 缓存击穿如何解决加锁更新查询缓存,发现缓存中不存在,加锁,让其它线程等待,只让一个线程去更新缓存。 异步更新还有一个可行的方案是把缓存设置永不过期。那缓存怎么更新呢?通过异步的方式去更新缓存。 比如后台设置一个守护线程定时更新缓存,但这种定时比较难以把握。 异步更新机制实际上更适合用于缓存预热。 缓存穿透什么是缓存穿透缓存穿透:缓存穿透指的查询缓存和数据库中都不存在的数据,这样每次请求直接打到数据库,就好像缓存不存在一样。 缓存穿透将导致不存在的数据每次请求都要到存储层去查询,失去了缓存保护后端存储的意义。 缓存穿透可能会使后端存储负载加大,如果发现大量存储层空命中,可能就是出现了缓存穿透问题。 缓存穿透可能有两种原因:
我们来看看如何解决。 缓存穿透如何解决缓存空值/默认值一种方式是在数据库不命中之后,把一个空对象或者默认值保存到缓存,之后再访问这个数据,就会从缓存中获取,这样就保护了数据库。 缓存空值有两大问题:
布隆过滤器除了缓存空对象,我们还可以在存储和缓存之前,加一个布隆过滤器,做一层过滤。 布隆过滤器里会保存数据是否存在,如果判断数据不不能再,就不会访问存储。 那布隆过滤器是什么玩意儿?查找它会不会很慢? 布隆过滤器是什么? 不知道你对哈希表了解多少,布隆过滤器是一个类似的东西。 它是一个连续的数据结构,每个存储位存储都是一个 存储数据的时时候,使用K个不同的哈希函数将这个变量映射为bit列表的的K个点,把它们置为1。 我们判断缓存key是否存在,同样,K个哈希函数,映射到bit列表上的K个点,判断是不是1:
至于为什么?因为哈希函数是存在碰撞的可能的。 关于缓存穿透的两种主要解决方案,我们简单对比一下: 缓存雪崩接下来我们看最严重的一种情况,缓存雪崩。 什么是缓存雪崩缓存雪崩: 当某?时刻发??规模的缓存失效的情况,例如缓存服务宕机、大量key在同一时间过期,这样的后果就是?量的请求进来直接打到DB上,可能导致整个系统的崩溃,称为雪崩。 缓存雪崩如何解决缓存雪崩是三大缓存问题里最严重的一种,我们来看看怎么预防和处理。 提高缓存可用性
过期时间
熔断降级
总结一张图总结: 参考: [1]. 《Redis开发与运维》 [2]. 《极客时间 高并发系统设计四十问》 [5]. 布隆过滤器,没那么难 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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/23 20:22:30- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |