缓存使用-缓存击穿、穿透、雪崩概念

一、缓存穿透

指查询一个不存在的数据、由于缓存不命中,将查询数据库,但是数据库也无此记录,我们没有将null写入缓存,这将导致这个不存在数据每次请求都会查询数据库,导致缓存失去意义。

风险:

利用不存在的数据进行攻击,数据库会瞬间压力增大,最终可能导致崩溃。

解决:

null结果依然缓存,并加入短暂过期时间。

二、缓存雪崩

缓存雪崩是指在我们设置缓存时key采用了相同的过期时间,导致缓存在某一时刻同时失效,请求全部转发到数据库中,数据看瞬时压力过大导致雪崩。

解决:

原有的失效时间基础上增加一个随机值,例如1-5分钟随机,这样每一个缓存的国旗时间的重复率将会降低,就可以很好的规避集体失效。

三、缓存击穿

对于一些设置了过期时间的key。如果这些key可能会在某些时间点被超高并发的访问,是一种非常"热点"的数据。

如果这个key在大量请求同时进来前正好失效,那么所有对这个key的数据查询都会落到数据库中,我们称为缓存击穿。

解决:

加锁,大量并发只让一个去查数据库,其他进行等待,查到以后释放锁、其他人获取到锁先查询缓存,这时缓存就已经存在缓存数据,避免再去数据库查询。

相关推荐
星辰_mya4 分钟前
系统里的“特种部队”——缓存
缓存
snow@li21 分钟前
数据库-Redis:常用语法 / Redis 核心知识技能梳理
数据库·redis·缓存
fuquxiaoguang1 小时前
金蝶天燕AMDC:当企业级缓存遇见Redis 8.2,国产中间件的“性能+易用”双飞跃
redis·缓存·中间件
AI木马人10 小时前
9.【AI任务队列实战】如何在高并发下保证系统不崩?(Redis + Celery完整方案)
数据库·人工智能·redis·神经网络·缓存
CyrusCJA19 小时前
在Windows系统上将Redis注册为系统服务使其实现开机自启
数据库·windows·redis·缓存
逆境不可逃1 天前
一篇速通Redis 从原理到Java实战(含缓存问题解决方案+集群配置)
数据库·redis·缓存
studytosky1 天前
【高并发内存池】线程缓存核心原理与实现
linux·服务器·git·缓存
Lanren的编程日记1 天前
Flutter 鸿蒙应用内存管理优化实战:对象池+智能缓存+泄漏检测,全方位提升应用稳定性
flutter·缓存·华为·harmonyos
耳边轻语9991 天前
Hermes 如何省token-配置
人工智能·缓存