缓存穿透、缓存击穿、缓存雪崩以及解决方案

本文详细讨论了Java面试中可能遇到的缓存问题,包括缓存穿透、缓存击穿和缓存雪崩,以及相应的解决方案,如使用exists命令处理穿透、分布式锁防止击穿和数据预热应对雪崩。
摘要由CSDN通过智能技术生成

Java面试题

缓存穿透

缓存中和数据库中都没有数据被大量请求,这些请求直接穿透到数据库中,失去了缓存层存在的意义,导致数据库压力过大。

解决方案:

1.数据库中获取不到数据时,将null值放入到缓存中。Redis缓存中可以使用exists命令判断数据是否存在于缓存中,而不是通过值是否为null来判断。(伪造数据攻击时,此方法也会导致缓存中数据增多,所以此类缓存过期时间可以稍微短点儿。)

2.接口层设置拦截。拦截不符合规则的数据,比如请求过来非11位的手机号,全部拦截下来。

缓存击穿

缓存中没有但数据库中存在的某个热点数据,大量请求直接到达数据库。

解决方案:

1.锁。使用分布式锁,保证只有一个请求到数据库中。

2.自动续期。利用定时任务,在缓存失效前通过查询数据库来更新缓存。

3.热点数据设置为永不过期。

缓存雪崩

缓存中数据大面积失效或缓存服务不可用时,大量请求直接到达数据库。

解决方案:

1.缓存中数据的失效时间增加随机值。

2.数据预热。秒杀活动开始前,将所有秒杀商品提前加载到缓存中。

3.使用高可用的缓存部署。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值