缓存穿透、击穿、雪崩

缓存穿透:

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

解决方案:

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

缓存击穿:

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

解决方案:

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

缓存雪崩:

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

解决方案:

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

相关推荐
lang201509281 天前
Kafka元数据缓存机制深度解析
分布式·缓存·kafka
源代码•宸1 天前
分布式缓存-GO(简历写法、常见面试题)
服务器·开发语言·经验分享·分布式·后端·缓存·golang
LYFlied1 天前
【每日算法】LeetCode 146. LRU 缓存机制
前端·数据结构·算法·leetcode·缓存
FrameNotWork2 天前
HarmonyOS 教学实战(二):加入网络请求与缓存(让你的应用真正“像个正式 App”)
缓存·华为·harmonyos
叫我龙翔2 天前
【Redis】从零开始掌握redis --- 认识redis
数据库·redis·缓存
源代码•宸2 天前
goframe框架签到系统项目(安装 redis )
服务器·数据库·经验分享·redis·后端·缓存·golang
忍冬行者2 天前
清理三主三从redis集群的过期key和键值超过10M的key
数据库·redis·缓存
TimberWill2 天前
使用Redis队列优化内存队列
数据库·redis·缓存
梦里不知身是客112 天前
redis的缓存击穿原因
redis·缓存·bootstrap
GGBondlctrl2 天前
【Redis】从单机架构到分布式,回溯架构的成长设计美学
分布式·缓存·架构·微服务架构·单机架构