快取技術可以用來減輕資料庫的壓力,提升存取效率。目前在企業專案中對快取也是越來越重視。但是快取不是說隨便加入專案就可以了。將快取整合到專案中,這才是第一步。而緩存帶來的穿透問題,進而導致的雪蹦問題都是我們迫切需要解決的問題。這篇文章將我平時專案中的解決方案分享給大家,以供參考。
快取的正常使用如圖:
如圖所示,快取的使用流程:
1、先從快取取數據,如果能取到,直接回傳資料給使用者。這樣不用存取資料庫,減輕資料庫的壓力。
2、如果快取中沒有數據,就會存取資料庫。
這裡面就會存在一個BUG,如圖:
#如圖,快取就像是資料庫的一道防火牆,將請求比較頻繁的數據放到快取中,從而減輕資料庫的壓力。但是如果有人惡意攻擊,那就很輕鬆的穿透你的緩存,將所有的壓力都給資料庫。例如上圖,你快取的key都是正整數,但是我偏偏使用負數作為key存取你的緩存,這樣就會導致穿透緩存,將壓力直接給資料庫。
快取穿透的問題,肯定是再大並發情況下。依此為前提,我們分析快取穿透的原因如下:
1、惡意攻擊,猜測你的key命名方式,然後估計使用一個你快取中不會有的key進行存取。
2、第一次數據訪問,這時快取中還沒有數據,則並發場景下,所有的請求都會壓到資料庫。
3、資料庫的資料也是空,這樣即使存取了資料庫,也是取得不到數據,那麼快取中肯定也沒有對應的資料。這樣也會導致穿透。
快取穿透在於一步步規避穿透的原因,如圖:
##如上圖所示,解決的步驟如下:更多Redis相關技術文章,請造訪Redis教學##欄位進行學習!
以上是redis緩存穿透怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!