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

一、缓存穿透

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

风险:

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

解决:

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

二、缓存雪崩

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

解决:

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

三、缓存击穿

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

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

解决:

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

相关推荐
醇醛酸醚酮酯4 小时前
多线程是如何保证数据一致和MESI缓存一致性协议
缓存
代码老y21 小时前
穿透、误伤与回环——Redis 缓存防御体系的负向路径与治理艺术
数据库·redis·缓存
Code季风21 小时前
深度优化 spring 性能:从缓存、延迟加载到并发控制的实战指南
java·spring boot·后端·spring·缓存·性能优化
Themberfue21 小时前
Redis ①⑥-缓存
数据库·redis·adb·缓存
Hello.Reader1 天前
RedisJSON 路径语法深度解析与实战
数据库·redis·缓存
千宇宙航1 天前
闲庭信步使用图像验证平台加速FPGA的开发:第十课——图像gamma矫正的FPGA实现
图像处理·计算机视觉·缓存·fpga开发
Alfred king1 天前
面试150 LRU缓存
链表·缓存·哈希表·lru·双向链表
岸边的风1 天前
退出登录后头像还在?这个缓存问题坑过多少前端!
前端·缓存·状态模式
Liudef061 天前
大模型KV缓存量化误差补偿机制:提升推理效率的关键技术
人工智能·缓存
在未来等你1 天前
Redis面试精讲 Day 1:Redis核心特性与应用场景
数据库·redis·缓存·nosql·面试准备