想要了解这些东西就必须了解缓存处理流程:
前台请求,后台就会访问缓存去取数据,如果取到了就会直接返回数据;(重点)如果取不到,那么就会直接访问数据库去数据库里面取数据,然后将取到的数据更新缓存,并且返回结果;如果数据库也没有取到,那么就会返回空值。了解了缓存处理过程之后,我们来讲他们三种情况的区别和解决方案。
1缓存穿透:它是指缓存和数据库中都没有数据,但是呢用户又不断的发起访问请求,这是的请求者很可能是攻击者,如果一直这样呢不间断访问,会导致数据库压力过载。
解决方案:增加接口校验,用户权限校验,基础数据请求校验,如果在缓存和数据库都没有取到数据,这时可以讲key_value设置为key-null,可以将缓存时效缩短,这样就可以防止被听一个id使用暴力攻击。
2缓存击穿:一般是指缓存到期,然后在缓存取请求不到数据,这时候并发的用户又特别多,同时又在缓存读不到数据,这时候就会同时取数据库请求数据然后史数据库压力瞬间增大。
解决方案:可以设置经常被访问的热点数据永不过期,或者加一个互斥锁。
4缓存雪崩:是指缓存中数据同时大批量达到过期时间,此时大量并发访问数据库请求数据,导致数据库过载的现象,和缓存击穿不同的是,它是高并发同时访问多条缓存里已经过期的数据,而缓存击穿是高并发访问同一天数据。
解决方案:缓存的过期时间设置为随机,避免大面积同时到期,