Redis网红面试题三连
-
面试题1:怎么解决缓存穿透问题的?
-
面试题2:说一下缓存击穿吧,你们是怎么解决的?
-
面试题3:那缓存雪崩说说你们是怎么解决的?
面试题1:怎么解决缓存穿透问题的?
缓存穿透:指缓存和数据库中都没有的数据,导致所有的请求都打到数据库上,然后数据库还查不到(如null),没法写缓存,造成数据库短时间线程数被打满而导致其他服务阻塞,最终导致线上服务不可用。此时缓存就好像被穿透了一样,起不到任何作用。
当然,使用缓存难免会有穿透的发生。
-
缓存容量有限,不可能去缓存所有数据,查询到未被缓存的数据就会发生穿透是正常情况。
-
互联网业务的数据访问模型一般是遵循二八原则的,即 20% 的数据为热点数据,80% 的数据是非热点不被常访问的数据。既然缓存容量有限,且20%的数据为热点数据,那我们可以利用有限的容量去缓存那 20% 的数据来保护我们的系统,至于80%非热点不常用的数据发生穿透就穿透了,数据库吃得住。
那我们怎样来解决这种缓存穿透问题呢?
-
接口参数校验:
防君子不防小人。在参数校验层加上参数合法性校验