缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题( 四 )

2、缓存数据:它的过期时间比缓存标记的时间延长1倍 , 例:标记缓存时间30分钟 , 数据缓存设置为60分钟 。 这样 , 当缓存标记key过期后 , 实际缓存还能把旧数据返回给调用端 , 直到另外的线程在后台更新完成后 , 才会返回新缓存 。

关于缓存崩溃的解决方法 , 这里提出了三种方案:使用锁或队列、设置过期标志更新缓存、为key设置不同的缓存失效时间 , 还有一各被称为“二级缓存”的解决方法 , 有兴趣的读者可以自行研究 。

二、缓存穿透

缓存穿透是指用户查询数据 , 在数据库没有 , 自然在缓存中也不会有 。 这样就导致用户查询的时候 , 在缓存中找不到 , 每次都要去数据库再查询一遍 , 然后返回空(相当于进行了两次无用的查询) 。 这样请求就绕过缓存直接查数据库 , 这也是经常提的缓存命中率问题 。

有很多种方法可以有效地解决缓存穿透问题 , 最常见的则是采用布隆过滤器 , 将所有可能存在的数据哈希到一个足够大的bitmap中 , 一个一定不存在的数据会被这个bitmap拦截掉 , 从而避免了对底层存储系统的查询压力 。

推荐阅读