最近,总是多次被人问起是否了解 Redis缓存穿透、击穿或者雪崩的问题。因为,我是个较为务实的程序员,习惯于在工作中实事求是的分析和解决各种问题,而并不喜欢死记硬背各种名词或者概念,也经常对网络上一些相关技术文章持有怀疑的态度。因此,导致忽然被问到相关问题时,回答或许不太尽如人意。
一、回归正题,我们先理解一下缓存穿透、击穿与雪崩这几个名词:是什么?
1、什么是缓存穿透:是指缓存与数据库中同时没有相关数据的情况下,但是每次的请求都需要先访问一次缓存,再访问一次数据库的现象。
2、什么是缓存击穿:是指数据库中有相关数据,但缓存中没有数据的情况下(比如缓存时间过期),瞬间产生大量的共同请求,为导致此刻相关的请求都需要先访问一次缓存,再访问一次数据库的现象。
3、什么是缓存雪崩:是指缓存中数据在某一时刻大量失效,造成数据库压力突然急剧增大的现象。
二、 问题根源的剖析:为什么?
首先,我们需要理解为什么已经使用数据库,却还需要缓存?缓存(比如 Redis)存在的价值在与主要四个方面:
1、将复杂条件的查询转变为简单的键值对查询;
2、内存优势;
3、分摊数据库的并发压力;
4、分摊数据库的计算压力。
接下来,分析一下为什么会出现穿透、击穿和雪崩的问题?
1、为什么出现穿透问题