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

一、缓存穿透

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

风险:

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

解决:

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

二、缓存雪崩

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

解决:

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

三、缓存击穿

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

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

解决:

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

相关推荐
AwakeFantasy1 小时前
关于Codex中转站生图比例问题的解决记录
数据库·redis·缓存
剑傲娇2 小时前
【计算机组成原理】 数据通路 之单总线结构
缓存
夜白宋3 小时前
【Redis深入】一、快的原因
数据库·redis·缓存
宇砾4 小时前
浅谈Redis(2)
数据库·redis·缓存
cfm_29144 小时前
Redis Stack 零基础入门
数据库·redis·缓存
皮卡祺q5 小时前
【redis1】基本指令,五大数据类型,存储优化,使用场景】
数据库·redis·缓存
Mr. zhihao6 小时前
Redis Bitmap:BitCount、bitTop的使用业务场景
数据库·redis·缓存
闪电悠米6 小时前
黑马点评-分布式锁-02_simple_redis_lock_setnx
java·数据库·spring boot·redis·分布式·缓存·wpf
闪电悠米7 小时前
黑马点评-分布式锁-03_lua_atomic_unlock
java·数据库·分布式·缓存·oracle·wpf·lua
小马爱打代码7 小时前
SpringBoot + 本地缓存 + 布隆过滤器:防止恶意 ID 查询打穿数据库
数据库·spring boot·缓存