先来看一个常见的缓存使用方式:读请求来了,先查下缓存,缓存有值命中,就直接返回;缓存没命中,就去查数据库,然后把数据库的值更新到缓存,再返回。
缓存穿透
概述 : 当缓存中没有数据,就会去数据库中进行查找。当数据库中也没有数据,就不会将数据缓存到redis中。这就会导致每次请求都要到数据库中查询,导致数据库访问压力增大。
出现的原因:
- 1.业务设计不合理:比如大多数用户都没开守护,但是你的每个请求都去缓存,查询某个userid查询有没有守护。
- 2.业务/运维/开发的数据误删:由于操作业务/运维/开发的一些操作,导致数据库中的数据被误删。
- 3.黑客非法请求:黑客通过数据库中没有的数据进行请求访问。
解决方式:
- 1.在接口出校验数据是否正确
- 2.如果查询数据库中的数据为空,就给一个默认值。当数据发生改变时,修改默认值并更新缓存。同时给适当的过期时间。