快取穿透 快取雪崩 快取擊穿

2021-10-08 21:27:43 字數 646 閱讀 1218

快取穿透是指 百萬請求同時傳送查詢乙個資料庫並不存在的資料,造成資料庫查詢壓力過大,導致資料庫的崩潰,因為資料庫不存在這樣的資料所以例如redis的快取不會存起來才會導致百萬請求同時傳送給資料庫

快取穿透的應對措施:讓redis快取,快取起來不存在的資料,用0或者1這些不被用的數字快取起來,並且設定上自動過期時間

快取雪崩是指 百萬請求同時傳送查詢大量的資料庫存在而未被快取進redis裡面的資料,也就是大量的商品設定了相同的快取過期時間,他們同時在快取失效又同時被查詢了,這些資料在快取裡面大面積失效,所以這百萬請求又會同時請求資料庫導致資料庫崩潰

快取雪崩的應對措施:在redis快取這些大量的資料時,隨機分配他們的過期時間,讓他們不會同時過期

快取擊穿是指 乙個**熱點商品(key被頻繁查詢的商品)**在晚上會在快取裡面自動過期而失效,第二天早上突然百萬請求來查詢這個熱點商品,又同時查詢資料庫導致資料庫崩潰

快取擊穿的應對措施:給百萬請求加鎖,然後等乙個請求查到了資料快取到redis裡面其餘請求就可以直接從快取中拿資料了。

快取穿透 快取擊穿 快取雪崩

一 快取處理流程 前台請求,後台先從快取中取資料,取到直接返回結果,取不到時從資料庫中取,資料庫取到更新快取,並返回結果,資料庫也沒取到,那直接返回空結果。二 快取穿透 描述 快取穿透是指快取和資料庫中都沒有的資料,而使用者不斷發起請求,如發起為id為 1 的資料或id為特別大不存在的資料。這時的使...

快取穿透,快取擊穿,快取雪崩

所謂的快取穿透,簡單來講就是查詢某些不存在的key時,快取和資料庫查詢結果都為空,而空的結果又不被快取起來,而導致每次查詢都去請求資料庫層的情況。在流量大時,可能db就掛掉了,要是有人利用不存在的key頻繁攻擊我們的應用,這就是漏洞。過程 快取不命中,進而導致每次查詢都去查詢資料庫,快取也就失去了作...

快取穿透快取擊穿快取雪崩

1 快取穿透 1.1 什麼是快取穿透 快取穿透,是指查詢乙個資料庫一定不存在的資料 核心 快取和資料庫該值不存在 正常的使用快取流程大致是,資料查詢先進行快取查詢,如果key不存在或者key已經過期,再對資料庫進行查詢,並把查詢到的物件,放進快取。如果資料庫查詢物件為空,則不放進快取。1.2 帶來的...