缓存穿透、击穿、雪崩

缓存穿透:

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

解决方案:

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

缓存击穿:

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

解决方案:

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

缓存雪崩:

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

解决方案:

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

相关推荐
Drifter_yh3 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
鸽鸽程序猿3 小时前
【Redis】zset 类型介绍
数据库·redis·缓存
予枫的编程笔记3 小时前
【Redis核心原理篇2】Redis 单线程模型:为什么单线程还能这么快?
数据库·redis·缓存
青春:一叶知秋7 小时前
【Redis存储】redis事务
数据库·redis·缓存
专注VB编程开发20年17 小时前
早期的redis是进程内的字典列表操作,后面改成TCP网络调用
数据库·redis·算法·缓存
Dragon Wu17 小时前
SpringCache 缓存使用总结
spring boot·后端·spring·缓存·springcloud
专注VB编程开发20年19 小时前
单服务器的 IIS + ASP.NET页面来说不需要redis
数据库·redis·缓存
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧19 小时前
Jsoup: 一款Java的HTML解析器
java·开发语言·前端·后端·缓存·html
fchampion19 小时前
缓存穿透的相关内容
缓存
白太岁19 小时前
Redis:(6) 三级缓存+连接池与高性能 Redis 客户端封装
数据库·redis·缓存