来源  | 编程技术宇宙

责编 | Jerry

我是Redis

你好,我是Redis,一个叫Antirez的男人把我带到了这个世界上。

说起我的诞生,跟关系数据库MySQL还挺有渊源的。

在我还没来到这个世界上的时候,MySQL过的很辛苦,互联网发展的越来越快,它容纳的数据也越来越多,用户请求也随之暴涨,而每一个用户请求都变成了对它的一个又一个读写操作,MySQL是苦不堪言。尤其是到“双11”、“618“这种全民购物狂欢的日子,都是MySQL受苦受难的日子。

据后来MySQL告诉我说,其实有一大半的用户请求都是读操作,而且经常都是重复查询一个东西,浪费它很多时间去进行磁盘I/O。

后来有人就琢磨,是不是可以学学CPU,给数据库也加一个缓存呢?于是我就诞生了!

出生不久,我就和MySQL成为了好朋友,我们俩常常携手出现在后端服务器中。

应用程序们从MySQL查询到的数据,在我这里登记一下,后面再需要用到的时候,就先找我要,我这里没有再找MySQL要。

为了方便使用,我支持好几种数据结构的存储:

  • String

  • Hash

  • List

  • Set

  • SortedSet

  • Bitmap

  • ······

因为我把登记的数据都记录在内存中,不用去执行慢如蜗牛的I/O操作,所以找我要比找MySQL要省去了不少的时间呢。

可别小瞧这简单的一个改变,我可为MySQL减轻了不小的负担!随着程序的运行,我缓存的数据越来越多,有相当部分时间我都给它挡住了用户请求,这一下它可乐得清闲自在了!

有了我的加入,网络服务的性能提升了不少,这都归功于我为数据库挨了不少枪子儿。

缓存过期 & 缓存淘汰

不过很快我发现事情不妙了,我缓存的数据都是在内存中,可是就算是在服务器上,内存的空间资源还是很有限的,不能无节制的这么存下去,我得想个办法,不然吃枣药丸。

不久,我想到了一个办法:给缓存内容设置一个超时时间,具体设置多长交给应用程序们去设置,我要做的就是把过期了的内容从我里面删除掉,及时腾出空间就行了。

超时时间有了,我该在什么时候去干这个清理的活呢?

最简单的就是定期删除,我决定100ms就做一次,一秒钟就是10次!

我清理的时候也不能一口气把所有过期的都给删除掉,我这里面存了大量的数据,要全面扫一遍的话那不知道要花多久时间,会严重影响我接待新的客户请求的!

时间紧任务重,我只好随机选择一部分来清理,能缓解内存压力就行了。

就这样过了一段日子,我发现有些个键值运气比较好,每次都没有被我的随机算法选中,每次都能幸免于难,这可不行,这些长时间过期的数据一直霸占着不少的内存空间!气抖冷!

我眼里可揉不得沙子!于是在原来定期删除的基础上,又加了一招:

那些原来逃脱我随机选择算法的键值,一旦遇到查询请求,被我发现已经超期了,那我就绝不客气,立即删除。

这种方式因为是被动式触发的,不查询就不会发生,所以也叫惰性删除

可是,还是有部分键值,既逃脱了我的随机选择算法,又一直没有被查询,导致它们一直逍遥法外!而于此同时,可以使用的内存空间却越来越少。

而且就算退一步讲,我能够把过期的数据都删除掉,那万一过期时间设置的很长,还没等到我去清理,内存就吃满了,一样要吃枣药丸,所以我还得想个办法。

我苦思良久,终于憋出了个大招:内存淘汰策略,这一次我要彻底解决问题!

我提供了8种策略供应用程序选择,用于我遇到内存不足时该如何决策:

  • noeviction:返回错误,不会删除任何键值

  • allkeys-lru:使用LRU算法删除最近最少使用的键值

  • volatile-lru:使用LRU算法从设置了过期时间的键集合中删除最近最少使用的键值

  • allkeys-random:从所有key随机删除

  • volatile-random:从设置了过期时间的键的集合中随机删除

  • volatile-ttl:从设置了过期时间的键中删除剩余时间最短的键

  • volatile-lfu:从配置了过期时间的键中删除使用频率最少的键

  • allkeys-lfu:从所有键中删除使用频率最少的键

有了上面几套组合拳,我再也不用担心过期数据多了把空间撑满的问题了~

缓存穿透 & 布隆过滤器

我的日子过的还挺舒坦,不过MySQL大哥就没我这么舒坦了,有时候遇到些烦人的请求,查询的数据不存在,MySQL就要白忙活一场!不仅如此,因为不存在,我也没法缓存啊,导致同样的请求来了每次都要去让MySQL白忙活一场。我作为缓存的价值就没得到体现啦!这就是人们常说的缓存穿透

这一来二去,MySQL大哥忍不住了:“唉,兄弟,能不能帮忙想个办法,把那些明知道不会有结果的查询请求给我挡一下”

这时我想到了我的另外一个好朋友:布隆过滤器

我这位朋友别的本事没有,就擅长从超大的数据集中快速告诉你查找的数据存不存在(悄悄告诉你,我的这位朋友有一点不靠谱,它告诉你存在的话不能全信,其实有可能是不存在的,不过它他要是告诉你不存在的话,那就一定不存在)。

如果你对我这位朋友感兴趣的话,可以看看这里《白话布隆过滤器BloomFilter》。

我把这位朋友介绍给了应用程序,不存在的数据就不必去叨扰MySQL了,轻松帮忙解决了缓存穿透的问题。

缓存击穿 & 缓存雪崩

这之后过了一段时间太平日子,直到那一天···

有一次,MySQL那家伙正优哉游哉的摸鱼,突然一大堆请求给他怼了过去,给他打了一个措手不及。

一阵忙活之后,MySQL怒气冲冲的找到了我,“兄弟,咋回事啊,怎么一下子来的这么猛”

我查看了日志,赶紧解释到:“大哥,实在不好意思,刚刚有一个热点数据到了过期时间,被我删掉了,不巧的是随后就有对这个数据的大量查询请求来了,我这里已经删了,所以请求都发到你那里来了”

“你这干的叫啥事,下次注意点啊”,MySQL大哥一脸不高兴的离开了。

这一件小事我也没怎么放在心上,随后就抛之脑后了,却没曾想几天之后竟捅了更大的篓子。

那一天,又出现了大量的网络请求发到了MySQL那边,比上一次的规模大得多,MySQL大哥一会儿功夫就给干趴下了好几次!

等了好半天这一波流量才算过去,MySQL才缓过神来。

“老弟,这一次又是什么原因?”,MySQL大哥累的没了力气。

“这一次比上一次更不巧,这一次是一大批数据几乎同时过了有效期,然后又发生了很多对这些数据的请求,所以比起上一次这规模更大了”

MySQL大哥听了眉头一皱,“那你倒是想个办法啊,三天两头折磨我,这谁顶得住啊?”

“其实我也很无奈,这个时间也不是我设置的,要不我去找应用程序说说,让他把缓存过期时间设置的均匀一些?至少别让大量数据集体失效”

“走,咱俩一起去”

后来,我俩去找应用程序商量了,不仅把键值的过期时间随机了一下,还设置了热点数据永不过期,这个问题缓解了不少。哦对了,我们还把这两次发生的问题分别取了个名字:缓存击穿缓存雪崩

我们终于又过上了舒适的日子···

彩蛋

那天,我正在努力工作中,不小心出了错,整个进程都崩溃了。

当我再次启动后,之前缓存的数据全都没了,暴风雨似的请求再一次全都怼到了MySQL大哥那里。

唉,要是我能够记住崩溃前缓存的内容就好了···

预知后事如何,请关注后续精彩······

更多阅读推荐

  • 云原生安全模型与实践

  • 硅谷2020最新大数据学习路线:科学使用这一招,12周助你成为数据分析师

  • Service Mesh 在超大规模场景下的落地挑战

  • Swift、Flutter 共同瞄准 Windows!

  • 不是“老赖”是“真还”!罗永浩 6 亿债务还了 4 亿

还不懂Redis?看完这个故事就明白了!相关推荐

  1. 可用性SLA还不懂?看完这个故事就懂了

    大家好,我是小编云BliBli, 这些天 领导问了我一个暴击我灵魂的问题: 什么是SLA?那么多9到底是什么意思? (瓦特??我怎么知道???????) 但是领导都"屈尊"问我了 ...

  2. 看完这个故事,你就知道程序员为什么选公司就要去上升期的

    看完这个故事,你就知道程序员为什么选公司就要去上升期的 https://www.toutiao.com/i6948390604984402462/?tt_from=weixin&utm_cam ...

  3. 计算机显示器的三原色是,显示器参数看不懂?看完你就明白啦!

    原标题:显示器参数看不懂?看完你就明白啦! 对于电脑性能最直观的感受,就是通过显示器来感受.现在的各种显示器选择很多,各种参数也很多,无论是游戏.绘图.影视还是普通的商务用显示器都有不同的需求,因此选 ...

  4. 魅蓝5s 显示无服务器,今天发布的魅蓝5s到底坑不坑?看完这些你就明白了

    原标题:今天发布的魅蓝5s到底坑不坑?看完这些你就明白了 硬件学堂 给您带来更及时 更专业的IT硬件资讯 就等你的关注 昨天幸灾乐祸看红米Note4X新机首发,以前分分钟售罄的小米居然努力卖了1个小时 ...

  5. 计算机小白学UI,小白学UI设计有什么技巧?看完这些你就明白了

    原标题:小白学UI设计有什么技巧?看完这些你就明白了 随着互联网的快速发展,UI设计师成为近年来的职场新贵,不断增加的薪资让很多人羡慕不已,想要加入UI设计行业的人不断增多.对于小白来说,在UI设计学 ...

  6. 为了吾王哪个服务器稳定,为了吾王设定解释攻略 看完这个你就明白游戏怎么玩了...

    原标题:为了吾王设定解释攻略 看完这个你就明白游戏怎么玩了 为了吾王设定比较多,在游戏当中光看介绍并不是很清楚,这也导致了很多新手玩家得等到吃了亏或者是事件出现之后,才知道其中的一些设定,今天小编就带 ...

  7. 手机壳鸿蒙,手机壳后面为什么要放钱?好多人都不懂,看完我也放一张

    出门不带钱依然成为很多人的习惯,只要一个手机在手就能行万里路了,这说的是你的银行卡里面"粮食"充足,要不然你光拿个手机潇洒的出门,最后也只能恹恹的回来,所以还是先努力挣钱吧,才有资 ...

  8. 苹果电脑能恢复数据吗?看完分析你就明白了!

    苹果电脑里数据丢失了还能恢复吗?不管是Windows电脑的用户还是苹果电脑的用户,都可能会遭遇数据丢失的情况,在Windows系统下恢复数据的方法有很多,大多数的数据恢复软件也都是适用于Windows ...

  9. 台式计算机购买cpu,如何选购台式机电脑CPU?看完你就会明白

    CPU又称"中央处理器"是电脑的核心部件,也是我们选购时第一要看的部件,今天我们来说说如何选择台式机的CPU. 首先CPU分为两大类,一类INTEL(英特尔)另一类AMD,英特尔以 ...

最新文章

  1. NatApp 内网穿透工具简单使用介绍说明
  2. py---------面向对象进阶
  3. python调用ctypes中windll中的方法超时处理_python中使用ctypes调用MinGW生成的动态链接库(dll)...
  4. C语言一趟冒泡交换最小值,C语言单链表冒泡排序为啥以下代码实现不了?
  5. Zookeeper Tutorial 2 -- Programmer's Guide
  6. HGAT-用于半监督短文本分类的异构图注意力网络
  7. [Ext JS6]Ext.Template
  8. SVM-支持向量机(code实现)
  9. python requests 异步调用_构建高效的python requests长连接池详解
  10. 的谐音歌词_今日新歌,李诞肯定最烦这张谐音梗专辑
  11. spss入门——简单的数据预处理到时间序列分析系列(一)
  12. vue3笔记(乱七芭蕉更新中)
  13. PL3369C原边12W电源芯片
  14. 如何通过织云Lite愉快地玩转TSW
  15. Kotlin - 改良迭代器模式
  16. android系统怎么刷机教程,如何刷新Android系统? Android手机通用刷机教程
  17. C++元编程——CNN进行Minist手写数字识别
  18. 全面支持ROS,思岚科技发布SLAMWARE ROS SDK !
  19. 投影仪排行,三款家用投影仪品牌,极米坚果大眼橙你选哪一款?
  20. English--虚拟语气和条件状语从句

热门文章

  1. c 复杂的前置后置面试题_你被哪些C语言面试题坑过?
  2. python里元组和列表的共同点和不同点_Python元组与列表的相同点与区别
  3. iis7 php5 isapi配置,Windows7 IIS7下以FastCgi和ISAPI方法安装配置PHP5教程
  4. python二进制文件 删除尾部数据_在Python中读取和切片二进制数据文件的最快方法...
  5. php sqlite id自增,Android sqlite设置主键自增长的方法教程
  6. mysql存储过程触发器_MySQL存储过程及触发器
  7. js整体缩小网页_妙用JavaScript实现网页的任意缩放
  8. js在一个指定元素前添加内容_WebAR开发指南(1)---使用AR.js实现第一个WebAR demo...
  9. 北大保安又双叒…出“传奇”!这次是挑战“天下第一考”
  10. 重磅 | 第八届世界华人数学家大会将在清华大学举行