文章目录

  • 前言
  • 一、缓存预热
  • 二、缓存穿透
  • 三、缓存击穿
  • 四、缓存雪崩

前言

我们一般的系统,在达到一定QPS之后,都会启用缓存来抗压。而大部分缓存解决方案都是用的redis。
Redis具有简单,稳定,数据可持久化等特点。得到了很多公司的实际应用。
使用Redis 在达到一定的业务场景的时候,就会出现我们经常在面试中遇到的关于缓存的几个问题。
缓存预热,缓存穿透,缓存击穿,缓存雪崩


一、缓存预热

直面意思上来说,以APP作为例子。就是在用户还没打开我们APP之前。就已经把数据库里面的热点数据放入到缓存中了。这样用户在进入APP的时候,请求的是缓存的里面的记录。这样就极大的减少了对于数据库的压力。造成缓存击穿

实际场景: 我们有一款APP,每次准点会推送一些PUSH消息。这样很多用户在1分钟之内大量进入APP,导致并发量瞬间突增。如果所有的瞬时流量全部集中到数据库中,会导致系统整体压力非常大。所以这个时候在用户进去之前必须对首页的数据进行缓存预热。这样再大的压力也只会集中打到服务器和Redis上面。

总结:缓存预热就是提前给用户准备好饭菜。用户进系统不用等待(等待数据库查询),直接就能开吃

二、缓存穿透

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。我们在业务场景中,对于热点数据应该要做到所有的请求都打在这堵墙上,对于数据库尽量减少请求。缓存穿透的意思就是绕过了这堵墙,访问了在缓存中一定查询不到的数据,这样就会把所有的请求打到数据库,从而造成了数据库的压力。

实际场景:我们对于用户ID,针对每个用户ID,每请求一次会对用户信息生成一个缓存,缓存key值就是用户的ID值。但是当我们把用户ID换成-1进行请求,因为我们的用户ID肯定是会大于0的,所以如果有这样的请求,我们在缓存里面铁定查不到这条数据。就会把所有的请求打到数据里面,造成一次查询,增加数据库压力。

解决方案:针对数据库查询为空的数据,也进行缓存。缓存时间设置小点。或者设置边界值。上述场景 针对ID小于0的请求,直接报错,不让请求。

三、缓存击穿

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。击穿直面意思就是把墙的某一点打穿了。那这个点肯定是热点数据。由于这个key一直被大量请求。突然这个缓存失效了,一下子就会把大量的压力给到了数据库。造成系统崩溃。

实际场景:微博热搜就是这样的一个真实场景,随时随地都会有大量的请求在微博热搜上面。如果这个时候微博热搜缓存突然失效。这个时候所有压力都在数据库上面,就会造成数据库压力突增,系统崩溃。

解决方案:针对热点数据永不过期。热点数据只能我们去替换。让其永不过期。

四、缓存雪崩

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。然后每块砖是一个缓存key。假定用户每进行一次请求。我们会生成一次缓存。添一块砖。这样下次请求的压力也是在砖上。但由于我们缓存是有过期时间的。如果突然所有的砖在同一时刻全部崩塌。那这个时候一瞬间所有的请求又都会在数据库上面。造成数据库压力过大崩溃。

实际场景:在商品抢购,一波商品时间比较集中的放入缓存中,假设缓存设置一个小时,当过期时间到达后,这批商品会统一失效,而对于这批商品的访问查询,会直接落到数据库上,对于数据库而言,就会产生周期性的压力波峰,甚至会造成数据库宕掉。

解决方案:
1 针对key值设置随机过期时间,避免key值集中某一时间批量失效。
2 redis灾备。防止使用中redis主机崩溃导致系统崩溃
3 服务降级 优先提供核心服务

一篇文章搞清楚Redis 缓存预热,缓存击穿,缓存雪崩,缓存穿透。相关推荐

  1. 一篇文章搞定《RecyclerView缓存复用机制》

    一篇文章搞定<RecyclerView缓存复用机制> 前言 零.为什么要缓存 一.RecyclerView如何构建我们的列表视图 二.缓存过程 三.缓存结构 1.mChangedScrap ...

  2. Redis缓存击穿、雪崩、穿透!(超详细)

    缓存的击穿.穿透和雪崩应该是再熟悉不过的词了,也是面试常问的高频试题. 不过,对于这三大缓存的问题,有很多人背过了解决方案,却少有人能把思路给理清的. 而且,网络上仍然充斥着,大量不太靠谱的解决方案, ...

  3. 超硬核!!!一篇文章搞定TCP、UDP、Socket、HTTP(详细网络编程内容+现实解释三次握手四次挥手+代码示例)【网络编程 1】

    TCP.UDP.Socket 一天面试的经验: 什么是网络编程 网络编程中两个主要的问题 网络协议是什么 为什么要对网络协议分层 计算机网络体系结构 1 TCP / UDP 1.1 什么是TCP/IP ...

  4. 一篇文章搞定《Android布局优化》

    ------<一篇文章搞定Android布局优化> 前言 为什么要进行布局优化? Android绘制原理 双缓冲机制 布局加载原理 布局加载优化的一些方法介绍 AsyncLayoutInf ...

  5. 一篇文章搞懂filebeat(ELK)

    一篇文章搞懂filebeat(ELK) https://www.cnblogs.com/zsql/p/13137833.html 目录 一.filebeat是什么 1.1.filebeat和beats ...

  6. Android NDK开发之旅(2):一篇文章搞定Android Studio中使用CMake进行NDK/JNI开发

    Android NDK开发之旅(2):一篇文章搞定android Studio中使用CMake进行NDK/JNI开发 (码字不易,转载请声明出处:http://blog.csdn.NET/andrex ...

  7. 一篇文章搞定GVIM(根据工作经验持续更新)

    文章目录 0.引言 1.在Linux下面安装VIM 2.基本操作 2.1三种模式 2.1 保存退出:wq没反应?! 2.2 解决鼠标不能用的问题 2.3 VIM上下左右移动hjkl 2.4 跳转到第n ...

  8. 一篇文章搞定百度OCR图片文字识别API

    一篇文章搞定百度OCR图片文字识别API https://www.jianshu.com/p/7905d3b12104 转载于:https://www.cnblogs.com/chongdongxia ...

  9. c++ 计算正弦的近似值_一篇文章搞懂正弦保真性

    本文介绍数字信号处理中"正弦保真性"这一概念,想要更好地理解本文所述内容,建议读者先阅读<一篇文章搞懂卷积>. 正弦保真性定义 一个正弦信号作为线性时不变系统的输入时, ...

最新文章

  1. 大数相乘、大数相加、大数相减Java版本
  2. php判断访客语言,php实现获取及设置用户访问页面语言类
  3. 制作碳排放强度的空间可视化_【科研成果】吴传清、宋子逸:长江经济带农业碳排放的时空差异特征分析...
  4. MongoDB数据库(4.mongodb数据库的备份和恢复)
  5. Codeforces Testing Round #10 A. Forgotten Episode
  6. LoadRunner参数包含逗号
  7. 华为哪款手表支持鸿蒙,华为Watch 3最早或于5月发布 采用鸿蒙系统并支持eSIM
  8. Window服务初级教程以及log4net配置文件初始化
  9. CSDN积分获得途径
  10. 开源免费的pdf文档编辑器LibreOffice
  11. Fuji-ImageJ分割中央凹无血管区
  12. 减少USB 1.1 2.0 端口驱动程序延时_肉鸡啄羽、啄肛、啄蛋等现象如何减少,养殖的朋友们值得看一看...
  13. 2022-2027年中国文化传媒行业市场调研及未来发展趋势预测报告
  14. 两年制大专计算机网络技术,湖南都市五年制大专_计算机网络技术专业_2021年报名...
  15. 【Python123】鸡兔同笼
  16. QGIS制图中面积小的区域不显示注记
  17. php源码安装图文教程_织梦教程 整站源码通用安装教程内附图文说明
  18. python输入10个数据_分享10个数据分析的小技巧(Python)
  19. QQ、QQ空间、微信好友、微信朋友圈、新浪微博的分享。
  20. html表格 根据窗口调整,如何根据浏览器窗口大小动态调整html表格

热门文章

  1. 用Worktile管理园林景观设计项目,让多方协作更便捷
  2. 脚本(3D Survival Game Learning)
  3. VM安装mac安装步骤
  4. [图神经网络]视觉图神经网络ViG(Vision GNN)--论文阅读
  5. C 语言实例 - 计算一个数的 n 次方
  6. 方法返回多个值,使用Pair,Triple
  7. 2021水利水电安全员模拟考试判断题库及答案
  8. Android Launcher 如何去掉主菜单,所有应用摆在桌面,类似小米桌面
  9. pngquant java,使用pngquant批量压缩png
  10. python初学总结八数码小游戏