网站建设忽悠,仿第四城地方门户网站模板,福田欧辉新能源公交车,宁晋网站建设代理价格Java面试题
缓存穿透 缓存中和数据库中都没有数据被大量请求#xff0c;这些请求直接穿透到数据库中#xff0c;失去了缓存层存在的意义#xff0c;导致数据库压力过大。 解决方案#xff1a; 1.数据库中获取不到数据时#xff0c;将null值放入到缓存中。Redis缓存中可以…Java面试题
缓存穿透 缓存中和数据库中都没有数据被大量请求这些请求直接穿透到数据库中失去了缓存层存在的意义导致数据库压力过大。 解决方案 1.数据库中获取不到数据时将null值放入到缓存中。Redis缓存中可以使用exists命令判断数据是否存在于缓存中而不是通过值是否为null来判断。伪造数据攻击时此方法也会导致缓存中数据增多所以此类缓存过期时间可以稍微短点儿。 2.接口层设置拦截。拦截不符合规则的数据比如请求过来非11位的手机号全部拦截下来。 缓存击穿 缓存中没有但数据库中存在的某个热点数据大量请求直接到达数据库。 解决方案 1.锁。使用分布式锁保证只有一个请求到数据库中。 2.自动续期。利用定时任务在缓存失效前通过查询数据库来更新缓存。 3.热点数据设置为永不过期。 缓存雪崩 缓存中数据大面积失效或缓存服务不可用时大量请求直接到达数据库。 解决方案 1.缓存中数据的失效时间增加随机值。 2.数据预热。秒杀活动开始前将所有秒杀商品提前加载到缓存中。 3.使用高可用的缓存部署。