緩存穿透晃洒,是指查詢一個數(shù)據(jù)庫一定不存在的數(shù)據(jù)慨灭。正常的使用緩存流程大致是朦乏,數(shù)據(jù)查詢先進行緩存查詢,如果key不存在或者key已經(jīng)過期氧骤,再對數(shù)據(jù)庫進行查詢呻疹,并把查詢到的對象,放進緩存筹陵。如果數(shù)據(jù)庫查詢對象為空刽锤,則不放進緩存镊尺。
Redis緩存流程
代碼流程
參數(shù)傳入對象主鍵ID根據(jù)key從緩存中獲取對象如果對象不為空,直接返回如果對象為空并思,進行數(shù)據(jù)庫查詢?nèi)绻麖臄?shù)據(jù)庫查詢出的對象不為空庐氮,則放入緩存(設(shè)定過期時間)想象一下這個情況,如果傳入的參數(shù)為-1宋彼,會是怎么樣弄砍?這個-1,就是一定不存在的對象输涕。就會每次都去查詢數(shù)據(jù)庫音婶,而每次查詢都是空,每次又都不會進行緩存莱坎。假如有惡意攻擊衣式,就可以利用這個漏洞,對數(shù)據(jù)庫造成壓力檐什,甚至壓垮數(shù)據(jù)庫碴卧。即便是采用UUID,也是很容易找到一個不存在的KEY乃正,進行攻擊螟深。
小編在工作中,會采用緩存空值的方式烫葬,也就是【代碼流程】中第5步界弧,如果從數(shù)據(jù)庫查詢的對象為空,也放入緩存搭综,只是設(shè)定的緩存過期時間較短垢箕,比如設(shè)置為60秒。
緩存空值
緩存雪崩
緩存雪崩兑巾,是指在某一個時間段条获,緩存集中過期失效。
產(chǎn)生雪崩的原因之一蒋歌,比如在寫本文的時候帅掘,馬上就要到雙十二零點,很快就會迎來一波搶購堂油,這波商品時間比較集中的放入了緩存修档,假設(shè)緩存一個小時。那么到了凌晨一點鐘的時候府框,這批商品的緩存就都過期了吱窝。而對這批商品的訪問查詢,都落到了數(shù)據(jù)庫上,對于數(shù)據(jù)庫而言院峡,就會產(chǎn)生周期性的壓力波峰兴使。
小編在做電商項目的時候,一般是采取不同分類商品照激,緩存不同周期发魄。在同一分類中的商品,加上一個隨機因子俩垃。這樣能盡可能分散緩存過期時間欠母,而且,熱門類目的商品緩存時間長一些吆寨,冷門類目的商品緩存時間短一些赏淌,也能節(jié)省緩存服務(wù)的資源。
緩存時間加入suijiyinzi
其實集中過期啄清,倒不是非常致命六水,比較致命的緩存雪崩,是緩存服務(wù)器某個節(jié)點宕機或斷網(wǎng)辣卒。因為自然形成的緩存雪崩掷贾,一定是在某個時間段集中創(chuàng)建緩存,那么那個時候數(shù)據(jù)庫能頂住壓力荣茫,這個時候想帅,數(shù)據(jù)庫也是可以頂住壓力的。無非就是對數(shù)據(jù)庫產(chǎn)生周期性的壓力而已啡莉。而緩存服務(wù)節(jié)點的宕機港准,對數(shù)據(jù)庫服務(wù)器造成的壓力是不可預(yù)知的,很有可能瞬間就把數(shù)據(jù)庫壓垮咧欣。
緩存擊穿
緩存擊穿浅缸,是指一個key非常熱點,在不停的扛著大并發(fā)魄咕,大并發(fā)集中對這一個點進行訪問衩椒,當(dāng)這個key在失效的瞬間,持續(xù)的大并發(fā)就穿破緩存哮兰,直接請求數(shù)據(jù)庫毛萌,就像在一個屏障上鑿開了一個洞。
小編在做電商項目的時候喝滞,把這貨就成為“爆款”阁将。
其實,大多數(shù)情況下這種爆款很難對數(shù)據(jù)庫服務(wù)器造成壓垮性的壓力囤躁。達到這個級別的公司沒有幾家的冀痕。所以,務(wù)實主義的小編狸演,對主打商品都是早早的做好了準(zhǔn)備言蛇,讓緩存永不過期。即便某些商品自己發(fā)酵成了爆款宵距,也是直接設(shè)為永不過期就好了腊尚。
大道至簡,mutex key互斥鎖真心用不上满哪。
結(jié)束語
在流行的問題面前一定有流行的解決方案婿斥,但有時候,也要根據(jù)自己的實際情況酌情處理哨鸭。大膽設(shè)計民宿,說不定你的解決方案就會被流行呢?