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

Java面试题

缓存穿透

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

解决方案:

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

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

缓存击穿

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

解决方案:

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

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

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

缓存雪崩

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

解决方案:

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

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

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

你可能感兴趣的:(Java面试题,缓存)