Redis教程(十六):Redis的缓存穿透、缓存击穿、缓存雪崩

缓存穿透

描述

用户需要查询一个数据,例如要查一张ASSET_CODE = '999999'的卡片,查询redis中没有,就直接去请求数据库,数据库中也不存在对应的数据,返回空或错误,当很多用户同时请求并且都没有命中!于是都去请求了持久层的数据库,那么这样会给持久层数据库带来非常大的压力。当高并发或有人利用不存在的Key频繁攻击时,数据库的压力骤增,甚至崩溃,这就是缓存穿透问题。
*

解决方案

  1. 合法请求校验

  2. 缓存空对象

  3. 布隆过滤器

  4. 用户黑名单

缓存击穿

描述

生产上有一个非常热点的key,在不停的扛着大并发,当这个key失效时,一瞬间大量的请求冲到持久层的数据库中,就像在一堵墙上某个点凿开了一个洞!
*

解决方案

  1. 设置热点key永不过期

  2. 加互斥锁,同一时间只有一个线程能访问数据库查询这个key,查到了更新到缓存里,剩下的线程可以正常查询Redis缓存

缓存雪崩

描述

在某一个时间段,Redsi缓存的key大量集中同时过期失效了,所有的请求全部冲到持久层数据库上,导致持久层数据库挂掉!
*

解决方案

  1. 搭建redis集群

  2. 加互斥锁,同一时间只有一个线程能访问数据库查询这个key,查到了更新到缓存里,剩下的线程可以正常查询Redis缓存

  3. 设置不同的过期时间,让缓存失效的时间点尽量均匀

相关推荐
qq_54702617922 分钟前
Java 中的 Caffeine 缓存详解
java·开发语言·缓存
devilnumber2 小时前
Redis 使用过程中可能遇到的常见问题或 “坑”
数据库·redis·缓存
消失的旧时光-19432 小时前
Spring Boot + MyBatis 从 0 到 1 跑通查询接口(含全部踩坑)
spring boot·后端·spring·mybatis
摇滚侠2 小时前
Redis 和 MySQL 数据同步方案,ElasticSearch 和 MySQL 数据同步方案
java·redis·mysql
人道领域2 小时前
【黑马点评日记03】实战:Redis缓存穿透,缓存击穿,缓存雪崩全解析
java·开发语言·jvm·redis·spring·tomcat
披着羊皮不是狼2 小时前
(9)批量生成文章并同步存入 MySQL 和 Redis
数据库·redis·mysql
Devin~Y3 小时前
从Spring Boot到Spring AI:音视频AIGC内容社区Java大厂面试三轮连环问(含Kafka/Redis/安全/可观测性答案)
java·spring boot·redis·spring cloud·kafka·spring security·resilience4j
CDN3604 小时前
【踩坑实录】前端开发必看:一次由CSS缓存引发的线上事故与SEO反思
前端·css·缓存
1.14(java)4 小时前
MyBatis 操作数据库
数据库·mybatis
Aray12345 小时前
Redis Cluster 集群选举机制
数据库·redis·缓存