- 缓存穿透
是指查询一个数据库一定不存在的数据。正常的使用缓存流程大致是,- 数据查询先进行缓存查询,如果key不存在或者key已经过期,
- 再对数据库进行查询,并把查询到的对象,放进缓存。
- 数据库查询对象为空,则不放进缓存。
比如,一个缓存的key是1,那么查询的时候是有。但是传个-1,这个必定没有的,而且数据库返回也必定是空。这就会有人利用这个漏洞一直传不存在的key,导致数据库压力增大。
防范:一般把空值也缓存起来,但是可以把空值的缓存过期时间设置的短一点,这样就可以有效避免。
- 缓存雪崩
是指在某个时间段,缓存key集体过期,比如,我们一般都是设置key一过12点就过期,那么等到12点一到,缓存过期,数据库就需要抗住很大的压力,这很容易造成数据库宕机。
防范:可以分开设置过期的时间,规划一些key,分散过期,或者给个随机数的时间过期。 - 缓存击穿
是指一个key一直很火,很多数据都一直访问这个,不停的扛着大并发,但是如果有一段时间,key刚好过期,那段时间就只能直接请求数据库。
防范:一般这种很火的key,既然都已经很火,访问量大,那就设置为永不过期就可以了。
缓存击穿,缓存雪崩,缓存穿透原理和解决方法
最新推荐文章于 2024-08-13 08:15:00 发布