缓存穿透、击穿、雪崩

缓存穿透:

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

解决方案:

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

缓存击穿:

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

解决方案:

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

缓存雪崩:

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

解决方案:

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

相关推荐
1104.北光c°16 分钟前
【重写优化 新增绘图】布谷鸟过滤器:布隆过滤器的更优缓存穿透解?
java·开发语言·后端·缓存·缓存穿透·布隆过滤器·布谷鸟过滤器
希望永不加班1 小时前
SpringBoot 整合 Redis 缓存
spring boot·redis·后端·缓存·wpf
zz-zjx2 小时前
redis手动安装主从+哨兵
数据库·redis·缓存
小羊在睡觉12 小时前
Reids缓存穿透、击穿、雪崩
redis·缓存·go
m0_6125359916 小时前
redis入门到精通
数据库·redis·缓存
刘~浪地球17 小时前
Redis 从入门到精通(三):键操作命令详解
数据库·redis·缓存
刘~浪地球19 小时前
Redis 从入门到精通(四):字符串操作详解
数据库·redis·缓存
xhuiting20 小时前
Redis专题(二)
redis·缓存
zlp19921 天前
软考(系统架构师)-案例分析之Redis与缓存
redis·缓存·软考高级·软考·系统架构师
小雨青年1 天前
当缓存成为生产力:GitHub Actions 缓存机制的深度优化指南
缓存·github