**缓存穿透: **
产生原因: 当前端发送一条请求(这条请求缓存和数据库都没有)到后台,会先到缓存里找,没有再到数据库去找,也没有,如果有人恶意攻击会造成数据库蹦了,这就是穿透;
解决方法: 不管前面发的请求后台有没有数据,都给一个相应的值,比如一个" " 空字符串,在存到redies中,这样下次再来查就不会再到数据库中去查了;直接返回一个空字符串(无论有没有这条数据都返回一个值);
缓存击穿
产生原因: 缓存击穿,是指一个key非常热点(例如双十一期间进行抢购的商品数据),在不停的扛着大并发,大
并发集中对这一个点进行访问,当这个key在失效的瞬间,持续的大并发就穿破缓存,直接请求到数据
库上,就像在一个屏障上凿开了一个洞。
问题解决: 我们同样可以将这些热点数据设置永不过期就可以解决缓存击穿的问题了。
**缓存雪崩:
产生原因: 对于很短的时间段内redies缓存的信息都失效了,这时突然来了10000个请求前面失效的信息,会造成突然的都去找数据库查,造成数据库压力突然的增大(这就相当于雪崩).
解决方法: 对于不经常查的信息,存到redies时间短一点,对于热门的信息查询,存到redies中时间长一点,错开高峰期,可以这么理解,这样就能避免数据压力突然变大;