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

一、缓存穿透

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

风险:

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

解决:

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

二、缓存雪崩

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

解决:

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

三、缓存击穿

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

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

解决:

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

相关推荐
FL4m3Y4n11 小时前
MySQL缓存策略
数据库·mysql·缓存
野犬寒鸦11 小时前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
野犬寒鸦13 小时前
Redis热点key问题解析与实战解决方案(附大厂实际方案讲解)
服务器·数据库·redis·后端·缓存·bootstrap
菜菜小狗的学习笔记16 小时前
黑马程序员Redis--实战篇(黑马点评)
数据库·redis·缓存
zz-zjx16 小时前
harbor使用外置db,redis,存储(minio)通过pigsty安装(单机)
数据库·redis·缓存
CDN36018 小时前
CDN 缓存不生效 / 内容不更新?7 种原因 + 一键刷新方案
运维·网络安全·缓存
清水白石00818 小时前
《Python 性能优化实战:多进程并行 vs C/Rust/Cython 扩展的对比决策与团队落地指南》
python·spring·缓存
红云梦19 小时前
互联网三高-高性能之多级缓存架构
java·redis·缓存·架构·cdn
歪瑞马奇20 小时前
Course17:SGLang 深度优化:Radix 缓存与复杂任务的极致吞吐
缓存
小松加哲20 小时前
Spring AOP 代理创建时机深度解析:初始化阶段 vs 三级缓存(源码级)
java·spring·缓存