Redis网红高频面试题三连:缓存穿透?缓存击穿?缓存雪崩?

Redis网红面试题三连

  • 面试题1:怎么解决缓存穿透问题的?

  • 面试题2:说一下缓存击穿吧,你们是怎么解决的?

  • 面试题3:那缓存雪崩说说你们是怎么解决的?

Redis网红高频面试题三连:缓存穿透?缓存击穿?缓存雪崩?_第1张图片

面试题1:怎么解决缓存穿透问题的?

缓存穿透:指缓存和数据库中都没有的数据,导致所有的请求都打到数据库上,然后数据库还查不到(如null),没法写缓存,造成数据库短时间线程数被打满而导致其他服务阻塞,最终导致线上服务不可用。此时缓存就好像被穿透了一样,起不到任何作用。

当然,使用缓存难免会有穿透的发生。

  • 缓存容量有限,不可能去缓存所有数据,查询到未被缓存的数据就会发生穿透是正常情况。

  • 互联网业务的数据访问模型一般是遵循二八原则的,即 20% 的数据为热点数据,80% 的数据是非热点不被常访问的数据。既然缓存容量有限,且20%的数据为热点数据,那我们可以利用有限的容量去缓存那 20% 的数据来保护我们的系统,至于80%非热点不常用的数据发生穿透就穿透了,数据库吃得住。

那我们怎样来解决这种缓存穿透问题呢?

  • 接口参数校验:

防君子不防小人。在参数校验层加上参数合法性校验

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