更新時間:2023年08月25日17時21分 來源:傳智教育 瀏覽次數(shù):
緩存雪崩是緩存中大量key失效后當高并發(fā)到來時導致大量請求到數(shù)據(jù)庫,瞬間耗盡數(shù)據(jù)庫資源,導致數(shù)據(jù)庫無法使用。
造成緩存雪崩問題的原因是是大量key擁有了相同的過期時間,比如對課程信息設置緩存過期時間為10分鐘,在大量請求同時查詢大量的課程信息時,此時就會有大量的課程存在相同的過期時間,一旦失效將同時失效,造成雪崩問題。
1、使用同步鎖控制查詢數(shù)據(jù)庫的線程
使用同步鎖控制查詢數(shù)據(jù)庫的線程,只允許有一個線程去查詢數(shù)據(jù)庫,查詢得到數(shù)據(jù)后存入緩存。
Java synchronized(obj){ //查詢數(shù)據(jù)庫 //存入緩存 }
2、對同一類型信息的key設置不同的過期時間
通常對一類信息的key設置的過期時間是相同的,這里可以在原有固定時間的基礎上加上一個隨機時間使它們的過期時間都不相同。示例代碼如下:
Java //設置過期時間300秒 redisTemplate.opsForValue().set("course:" + courseId, JSON.toJSONString(coursePublish),300+new Random().nextInt(100), TimeUnit.SECONDS);
3、緩存預熱
不用等到請求到來再去查詢數(shù)據(jù)庫存入緩存,可以提前將數(shù)據(jù)存入緩存。使用緩存預熱機制通常有專門的后臺程序去將數(shù)據(jù)庫的數(shù)據(jù)同步到緩存。