缓存穿透、击穿、雪崩

缓存穿透:

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

解决方案:

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

缓存击穿:

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

解决方案:

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

缓存雪崩:

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

解决方案:

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

相关推荐
IT利刃出鞘40 分钟前
WordPress插件--Redis Object Cache对象缓存插件的用法
数据库·redis·缓存
Roye_ack44 分钟前
【黑马点评 - 高级篇】Redis分布式缓存原理(Redis持久化 RDB AOF + 主从集群 哨兵 分片集群 + 多级缓存)
redis·分布式·缓存·aof·redis持久化·rdb·redis主从哨兵分片集群
L.EscaRC1 小时前
Redis大Key与内存不足问题深度解析与应对策略
数据库·redis·缓存
chushiyunen3 小时前
redis命令 geo(对地理坐标的支持)
数据库·redis·缓存
Jtti8 小时前
PHP项目缓存占用硬盘过大?目录清理与优化
java·缓存·php
哥哥还在IT中9 小时前
缓存架构设计模式:Cache-Aside, Read-Through/Write-Through详解
spring boot·spring·缓存
Charles_go12 小时前
C#中级8、什么是缓存
开发语言·缓存·c#
q***040512 小时前
Nginx 缓存清理
运维·nginx·缓存
movie__movie16 小时前
秒杀库存扣减可以用redis原子自增么
数据库·redis·缓存
Y***K43420 小时前
后端缓存策略设计,多级缓存架构实践
缓存·架构