Java开发面试题:Redis三兄弟穿透、击穿、雪崩

缓存穿透查询一个不存在的数据,mysql查询不到数据也不会直接写入缓存,就会导致每次请求都查数据库

解决方案一:缓存空数据,查询返回的数据为空,仍把这个空结果进行缓存

优点:简单

缺点:消耗内存,可能会发生不一致的问题

解决方案二:布隆过滤器

优点:内存占用较少,没有多余key

缺点:实现复杂,存在误判

缓存击穿:给某一个key设置了过期时间,当key过期的时候,恰好这时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮

解决方案一:互斥锁  。

        强一致,性能差

解决方案二:逻辑过期

        高可用,性能优

缓存雪崩是指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。

解决方案:

1.给不同的Key的TTL添加随机值

2.利用Redis集群提高服务的可用性

3.给缓存业务添加降级限流策略

4.给业务添加多级缓存

总结:

穿透:缓存空数据,布隆过滤器

缓存击穿:过期key

雪崩:大量过期key,过期时间采用随机。

Redis这三个问题都可用限流来处理。

你可能感兴趣的:(Java开发面试题,java,redis,开发语言,面试)