缓存穿透、击穿、雪崩

缓存穿透:

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

解决方案:

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

缓存击穿:

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

解决方案:

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

缓存雪崩:

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

解决方案:

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

相关推荐
weixin_466820 小时前
Redis数据库基础
数据库·redis·缓存
Lucky小小吴1 天前
开源项目解读4-高性能并发缓存库Ristretto
缓存·开源·高并发·高性能缓存·实时数据处理·ristretto·tinylfu
亮子AI1 天前
【NestJS】在 nest.js 项目中,如何使用 Postgresql 来做缓存?
开发语言·缓存·node.js·nest.js
好大的月亮1 天前
oss中的文件替换后chrome依旧下载到缓存文件概述
前端·chrome·缓存
CodeAmaz1 天前
SpringBoot两级缓存实现
spring boot·spring·缓存
小丁爱养花2 天前
Redis 内部编码/单线程模型/string
数据库·redis·缓存·1024程序员节
爬山算法2 天前
Redis(84)如何解决Redis的缓存击穿问题?
java·redis·缓存
Merlos_wind2 天前
【Redis典型应用——缓存详解】
数据库·redis·缓存
缘友一世2 天前
LLama 3分组查询注意力与KV缓存机制
人工智能·深度学习·缓存·transformer·llama·gqa·kv缓存
阿祥~2 天前
windows 安装 Redis
数据库·redis·缓存