缓存穿透、击穿、雪崩

缓存穿透:

指的是恶意用户或攻击者通过请求不存在于缓存和后端存储中的数据来使得所有请求都落到后端存储上,导致系统瘫痪。

解决方案:

通常包括使用布隆过滤器或者黑白名单等方式来过滤掉无效请求,以及在应用程序中加入缓存预热等机制。

缓存击穿:

指的是在高并发访问下,某个热点数据失效后,大量请求同时涌入后端存储,导致后端存储负载增大、响应时间变慢,甚至瘫痪。

解决方案:

通常包括使用互斥锁或者分布式锁来对并发请求进行控制,避免对同一资源的并发读写竞争,另外也可以使用热点数据预加载等机制来提前将热点数据加入缓存,在其失效时快速刷新缓存。

缓存雪崩:

指的是因为某些原因导致缓存中大量的数据同时失效或过期,导致后续请求都落到后端存储上,从而引起系统负载暴增、性能下降甚至瘫痪。

解决方案:

通常包括使用分布式缓存部署、设置不同的过期时间、应用程序限流等措施来避免缓存失效时间集中在同一时间段,以及使用缓存预热和自动刷新机制等手段来减轻缓存压力。

相关推荐
筱顾大牛27 分钟前
黑马点评---给查询店铺的缓存添加超时剔除和主动更新的策略
缓存
Volunteer Technology33 分钟前
缓存基础面试题
缓存
银河麒麟操作系统39 分钟前
服务器通用(全架构)【页缓存(Page Cache)原理与运维实践分析】技术文章
运维·服务器·缓存
代码探秘者40 分钟前
【Redis】双写一致性:延迟双删 / 读写锁 / 异步通知 / Canal,一文全解
java·数据库·redis·后端·算法·缓存
HwJack2044 分钟前
HarmonyOS ArkUI列表性能优化实战:懒加载与缓存的艺术
缓存·性能优化·harmonyos
秦jh_1 小时前
【Redis】通用命令、string类型
数据库·redis·缓存
李白的天不白1 小时前
ERROR Failed to compile with 9 errors 以来报错文件配置问题 缓存顽固问题
前端·缓存
知我Deja_Vu13 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
没有bug.的程序员14 天前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
troublea14 天前
ThinkPHP3.x高效学习指南
mysql·nginx·缓存