当前位置:   article > 正文

[Redis]——缓存击穿和缓存穿透及解决方案(图解+代码+解释)

[Redis]——缓存击穿和缓存穿透及解决方案(图解+代码+解释)

目录

一、缓存击穿(热点Key问题)

1.1 问题描述

1.2 解决方案及逻辑图

    1.2.1 互斥锁

    1.2.2 逻辑过期

二、缓存穿透

2.1 问题描述

2.2 解决方案逻辑图

2.2.1 缓存空对象

2.2.2 布隆过滤器


一、缓存击穿(热点Key问题)

  • 个人理解:

        这里先提前说一下,热点Key问题不考虑缓存穿透了,也就是不考虑命中空缓存了,因为这种一般用于活动秒杀,这些热点Key都是提前存储好的(貌似是这样的,我也不太确定~~)

1.1 问题描述

    经常被查询的一个Key突然失效或者宕机了,导致重建缓存,由于是热点Key,所以有不断的线程来查和重建缓存,导致大量数据到达数据库,这种我们称为缓存击穿

1.2 解决方案及逻辑图

    1.2.1 互斥锁

解释:

    如果未命中缓存,先获取互斥锁,获取锁之后要再次检查缓存,如果还是未命中进行缓存重建,这样当其他线程来的时候就会获取锁失败,这时我们让这个线程休眠一会,重新查询缓存,如果命中就返回嘛,如果没命中再次尝试获取锁,假设这次获取锁成功了,还是再次检查缓存,如果未命中重建缓存。

优点:可保证数据高一致性

缺点:性能低,可能发生死锁

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/248092?site
推荐阅读
相关标签