1、快取穿透
原因:指定查詢一個一定不存在的資料,我們去查詢某個商品,但是快取中沒有,那么就是直接查詢資料庫,高并發下假如同時100萬請求同時查詢,那么他就會直接穿過快取去查詢資料庫,那么它將會導致資料庫崩潰無法作業【一直查詢一個不存在的結果,導致快取一直不命中,全部來查詢資料庫,導致資料庫壓力過大,沒有將null結果寫入快取】
解決:null結果快取,并加入短暫過期時間,如果不加入過期時間,則后面一直查詢的都是空結果
2、快取雪崩
原因:假如我們給快取中放了許多資料,但是我們在放資料的時候給每個資料都設定了相同的過期時間,
在某一個時候這些資料同時在快取中失效,那么這個時候所有請求又將會直接同時去訪問資料庫,這時就會導致資料庫壓力過大,無法正常作業【大面積key同時失效】
解決:在存每一個資料的時候,在原有的失效時間上加上一個亂數,避免他們同時失效
3、快取擊穿
原因:我們訪問一個熱點的key,每天100萬查詢某款商品,但是在加入快取的時候,給他設定了過期時間,比如一天,正好到晚上失效了,到了第二天突然高峰期所有請求全部進來,但是此時快取已經失效了,這時所有請求將直接到資料庫,導致資料庫壓力過大【某一個key失效,它是一個高頻熱點資料】
解決:加鎖,大量并發只讓一個人去查,其他人等待,查到以后釋放鎖,其他人得到鎖,先查快取,就會回傳資料,不用去資料庫
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/184099.html
標籤:Java
上一篇:云原生quarkus框架專案實踐
下一篇:JAVA自學筆記(2)
