快取的雪崩,擊穿,穿透
前言
在將今天的內容之前,我們先來了解一下什么是快取,快取是用來干什么的,常用的快取有哪些?
什么是快取
我們要知道快取其實就是一個臨時的存盤器,那么快取里的資料就不是持久化的資料,只是在我們查詢的程序中,來提高我們的效率的東西,那么我們對資料庫的添加和洗掉,修改其實和快取的關系不大,主要是查詢,
快取的作用
快取主要是為了提高資料的讀取速度,因為服務器和應用客戶端之間存在著流量的瓶頸,所以讀取大容量資料時,使用快取來直接為客戶端服務,可以減少客戶端與服務器端的資料互動,從而大大提高程式的性能,
訪問請求的程序
首先用戶進行資料的查詢的時候,應該先到快取中查詢,如果沒有再到資料庫中查詢,如果有資料,回傳給用戶,并保存到我們的臨時快取中,
什么是快取雪崩
快取的雪崩就是,假如我們再處理高并發的專案時,我們的快取極大的減小了資料庫訪問的壓力,實作的我們資料庫不會再某一個時刻突然迎來大批量的訪問,但是如果這個時候我們的快取突然宕機,那么就可能導致我們的請求大批量的直接打在我們的資料庫上,導致我們的資料庫的直接宕機,在運維人員的搶修重啟后,資料訪問繼續,資料庫再次瞬間宕機,
快取雪崩的處理
1、快取資料的過期時間設定隨機,防止同一時間大量資料過期現象發生,
2、如果快取資料庫是分布式部署,將熱點資料均勻分布在不同搞得快取資料庫中,
3、設定熱點資料永遠不過期,
什么是快取穿透
其實和雪崩的理解相差不大,快取穿透是指快取和資料庫中都沒有的資料,而用戶不斷發起請求,如發起為id為“-1”的資料或id為特別大不存在的資料,那么,我們的請求資料也會直接越過快取直接打在資料庫上,導致我們的資料庫的宕機,一般這樣的情況有可能服務器遭到了惡意攻擊,
快取穿透的處理
1.在用戶請求的介面層增加一些校驗,例如:用戶鑒權校驗、引數傳值校驗等不合法的引數請求即直接回傳,開發者應該保持一個悲觀的態度,不要相信任何客戶端因為計算機本身不知道操作者是誰,任何引數都應該考慮到,
2.使用Redis高級資料結構布隆過濾器,他就是檢測資料庫中是否存在該key,不存在就直接回傳即可,
什么是快取擊穿
快取里面的一個key非常的火爆,在某一時間這個key剛好過期,大并發資料量擊穿了快取直接請求資料庫,導致資料庫壓力過大,嚴重情況會導致資料庫崩潰,這就是快取擊穿,例如:微博熱點新聞,某個明星又出緋聞了,然后大量的粉絲刷文章刷評論,一時間熱火朝天,突然請求這條微博的快取過期,那么大量的請求直接涌向資料庫,建立大量連接,資料庫還沒反應過來就崩了,
快取擊穿的處理
1.設定這個key永遠不會過期
2.程式控制請求資料庫的次數,比如添加互斥鎖、延時請求
3.服務器熔斷、降級,限制每個用戶的訪問次數,并且如果獲取不到資料即回傳一個固定的推薦頁面,
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/321357.html
標籤:其他
