redis面试题之缓存异常

什么是缓存击穿?

大量缓存数据在同一时间过期(失效)或者 Redis 发生故障宕机时,如果此时有大量的用户请求,都无法在 Redis 中处理,于是全部请求都直接访问数据库,从而导致数据库的压力骤增,严重的会造成数据库宕机,从而形成一系列连锁反应,造成整个系统崩溃。(大量数据同时过期,Redis 故障宕机)
解决办法:

均匀设置过期时间;(我们可以在对缓存数据设置过期时间时,给这些数据的过期时间加上一个随机数,这样就保证数据不会在同一时间过期。)
双 key 策略;(主 key,会设置过期时间,一个是备 key,不会设置过期)
后台更新缓存
构建 Redis 缓存集群

什么是缓存击穿?

缓存击穿是某个热点的key失效,大量请求集中对其进行请求,就会造成大量请求读redis缓存没读到数据,从而导致高并发访问mysql数据库,引起数据库压力剧增。这种现象就叫做缓存击穿。
解决办法:

采用互斥锁方案,保证同一时间只有一个业务线程更新缓存,未能获取互斥锁的请求,要么等待锁释放后重新读取缓存,要么就返回空值或者默认值。
不给热点数据设置过期时间
由后台异步更新缓存,在热点数据准备要过期前,提前通知后台线程更新缓存以及重新设置过期时间;

什么是缓存击穿?

缓存击穿是某个热点的key失效,大量请求集中对其进行请求,就会造成大量请求读redis缓存没读到数据,从而导致高并发访问mysql数据库,引起数据库压力剧增。这种现象就叫做缓存击穿。
解决办法:

采用互斥锁方案,保证同一时间只有一个业务线程更新缓存,未能获取互斥锁的请求,要么等待锁释放后重新读取缓存,要么就返回空值或者默认值。
不给热点数据设置过期时间
由后台异步更新缓存,在热点数据准备要过期前,提前通知后台线程更新缓存以及重新设置过期时间;

什么是缓存穿透?

当用户访问的数据,既不在缓存中,也不在数据库中,导致请求在访问缓存时,发现缓存缺失,再去访问数据库时,发现数据库中也没有要访问的数据,没办法构建缓存数据,来服务后续的请求。那么当有大量这样的请求到来时,数据库的压力骤增,这就是缓存穿透的问题。

缓存穿透的发生的一半情况
业务误操作,缓存中的数据和数据库中的数据都被误删除了,所以导致缓存和数据库中都没有数据;
黑客恶意攻击,故意大量访问某些读取不存在数据的业务;
应对缓存穿透的方案,常见的方案有三种。

解决方案:

第一种方案,非法请求的限制;
第二种方案,缓存空值或者默认值;
第三种方案,使用布隆过滤器快速判断数据是否存在,避免通过查询数据库来判断数据是否存在;

在这里插入图片描述
参考资料:
https://xiaolincoding.com/redis/cluster/cache_problem.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值