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. 设置不同的过期时间,让缓存失效的时间点尽量均匀

相关推荐
咖啡の猫20 分钟前
Redis命令-Hash命令
redis·php·哈希算法
scofield_gyb20 分钟前
Redis简介、常用命令及优化
数据库·redis·缓存
難釋懷22 分钟前
Redis搭建分片集群
数据库·redis·缓存
mcooiedo29 分钟前
Spring Boot与MyBatis
spring boot·后端·mybatis
神奇萝卜头2 小时前
Redis 主从复制实现原理深度详解
redis
只能是遇见3 小时前
【SpringBoot3】Spring Boot 3.0 集成 Mybatis Plus
spring boot·后端·mybatis
yashuk3 小时前
Redis的安装教程(Windows+Linux)【超详细】
linux·数据库·redis
中杯可乐多加冰3 小时前
Serverless 时代的内核革命——华为 openYuanrong 深度解析 异构多级缓存与 D2D 高速传输实测
缓存·华为·开源·serverless·openyuanrong
灰阳阳4 小时前
Redis的缓存机制
数据库·redis·缓存
wenlonglanying4 小时前
【Redis】设置Redis访问密码
数据库·redis·缓存