概念: 去查询缓存和数据库都不存在的数据,然后大量请求不存在的数据,导致数据库压力过大崩溃。
解决方案: 把不存在的数据null存入缓存,并给个短期的过期时间。
概念: 缓存采用相同的过期时间,然后在某一时刻会同时过期,然后请求全部访问数据库,导致数据库崩溃。
解决方案: 把过期时间随机。
概念: 某个会过期的缓存会被大量请求访问,然后在失效的一刻,大量请求访问数据库,导致数据库崩溃。
解决方案: 加锁,大量请求,先让一个请求去查询数据库,然后存在缓存,其余请求都去查询缓存。
加锁:
//1.只要是同一把锁,就能锁住需要这个锁的线程。
//因为springboot是单例的,又因为this代表当前对象,所以可以锁住访问的所有线程
synchronized(this){
//(1) 首先去缓存查询是否存在缓存,存在就不用去查询数据库。
//(2) 不存在去查询数据库并且放在缓存里面。
//注意:要把(1) 和 (2) 都放在锁里面操作。不然会出现锁的时序问题。
}
//2.在方法上直接加synchronized也行。