Redis 缓存穿透/缓存雪崩/缓存击穿问题

1.缓存预热

当 redis 服务器 首次接入时,服务器内是没有数据的-->当客户端发起请求时,所有的请求,都会访问 mysql 随着时间的推移,redis 上的 数据越来越多,mysql 承担的压力就会逐渐减小(客户端先查询 redis 如果没有查到,就再查询一次 mysql 查到了之后,就会把数据也写入到 redis 中);

如何解决?

缓存预热-->就是用来解决上述问题的:将定时生成 和 实时生成 相结合--先在离线的情况下,先把热点数据导入到 redis 中,此时 导入的这些热点数据,就能帮 mysql 承担很大的压力,随着时间的推移,逐渐使用新的热点数据,淘汰掉旧的数据;

2.缓存穿透

查询某个 key ,在 redis 中没有, mysql 中也没有--这个 key 也不会被更新到 redis 中

如何解决?

1.如果发现这个 key 在 redis 和mysql 中都不存在,就仍然写入到 redis 中 ,将 value 设置为一个空值(""),或者非法值;

2.引入 布隆过滤器,每次查询 redis / mysql 之前,先判断一下 key 是否在 布隆过滤器上存在;(布隆过滤器 本质 是 结合了 hash + bitmap 用比较小的空间开销,比较快的速度,实现针对 key 是否存在的判定)

3.缓存雪崩

由于在短时间内,redis 上大规模的 key 失效,导致缓存命中率 下降,并且 mysql 压力迅速上升;

4.缓存击穿

相当于缓存雪崩的特殊情况,针对热点 key 突然过期了,导致大量的请求直接访问到数据库上,甚至引起数据库当即

如何解决?

基于统计的方式发现热点 key 并设置永不过期,

相关推荐
秋94 小时前
windows中安装redis
数据库·redis·缓存
oddsand16 小时前
Redis网络模型
java·数据库·redis
皮卡祺q6 小时前
【redies0-导论】分布式系统的演进-引进redis原因
java·数据库·redis
UrSpecial7 小时前
Redis与多线程
数据库·redis·缓存
会编程的土豆7 小时前
Redis Sorted Set(有序集合)详解
数据库·redis·bootstrap
万邦科技Lafite9 小时前
实战演练:利用京东API一键抓取商品详情
数据库·redis·python·缓存·开放api·淘宝开放平台
go不是csgo9 小时前
两个Redis数据结构搞定签到和UV统计:Bitmap与HyperLogLog实战
数据结构·redis·uv
橙子圆12310 小时前
Redis知识7之主从复制
数据库·redis·缓存
青柠代码录11 小时前
【Redis】数据类型:String
数据库·redis·缓存
IronMurphy14 小时前
Redis拷打第七讲(最终章)
数据库·redis·php