一.缓存穿透
概念: 去查询缓存和数据库都不存在的数据,然后大量请求不存在的数据,导致数据库压力过大崩溃。
解决方案: 把不存在的数据null存入缓存,并给个短期的过期时间。
二.缓存雪崩
概念: 缓存采用相同的过期时间,然后在某一时刻会同时过期,然后请求全部访问数据库,导致数据库崩溃。
解决方案: 把过期时间随机。
三.缓存击穿
概念: 某个会过期的缓存会被大量请求访问,然后在失效的一刻,大量请求访问数据库,导致数据库崩溃。
解决方案: 加锁,大量请求,先让一个请求去查询数据库,然后存在缓存,其余请求都去查询缓存。文章来源:https://www.toymoban.com/news/detail-728135.html
加锁:文章来源地址https://www.toymoban.com/news/detail-728135.html
//1.只要是同一把锁,就能锁住需要这个锁的线程。
//因为springboot是单例的,又因为this代表当前对象,所以可以锁住访问的所有线程
synchronized(this){
//(1) 首先去缓存查询是否存在缓存,存在就不用去查询数据库。
//(2) 不存在去查询数据库并且放在缓存里面。
//注意:要把(1) 和 (2) 都放在锁里面操作。不然会出现锁的时序问题。
}
//2.在方法上直接加synchronized也行。
到了这里,关于高并发下的缓存击穿、雪崩、穿透和分布式锁(三)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!