您好,登錄后才能下訂單哦!
這篇文章主要介紹“基于Redis緩存數據常見的問題如何解決”,在日常操作中,相信很多人在基于Redis緩存數據常見的問題如何解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”基于Redis緩存數據常見的問題如何解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
緩存穿透是在客戶端/瀏覽器端請求一個不存在的key,這個key在redis中不存在,在數據庫中也不存在數據源,每次對此key的請求從緩存獲取不到,就會請求數據源。
如使用一個不存在的用戶id去訪問用戶信息,redis和數據庫中都沒有,多次進行請求可能會壓垮數據源
一個一定不存在緩存及查詢不到的數據,由于緩存是不命中時被動寫入的,緩存不存在,出于容錯考慮,查詢不到的數據是不會緩存在redis當中,這將導致每次請求不存在的數據都會請求數據庫,失去了緩存的意義。
(1)如果一個查詢返回的數據為空(不管是數據是否不存在),我們仍然把這個空結果(null)進行緩存,設置空結果的過期時間會很短,最長不超過五分鐘
(2)設置可訪問的名單(白名單):使用bitmaps類型定義一個可以訪問的名單,名單id作為bitmaps的偏移量,每次訪問和bitmap里面的id進行比較,如果訪問id不在bitmaps里面,進行攔截,不允許訪問。
(3)采用布隆過濾器
(4)進行實時的數據監控,發現Redis在命中率急速降低時,排查訪問對象和訪問數據,設置黑名單。
當用戶請求一個存在的key的數據時,此時redis中該key的數據已經過時,此時若有大量并發請求發現緩存過期都會請求數據源加載數據并且緩存到redis當中,這個時候大量的并發可能會把數據庫服務壓垮。
key可能在某一個時間段被大量的請求,這個key的數據被稱為熱點數據,這個時候便要考慮“擊穿”問題。
(1)預先設置熱門數據:在redis高峰訪問之前,把一些熱門數據提前存入到redis里面,加大這些熱門數據key的時長
(2)實時調整:現場監控哪些數據熱門,實時調整key的過期時長
(3)使用鎖:
就是在緩存失效的時候(判斷拿出來的值為空),不是立即去load db。
先使用緩存工具的某些帶成功操作返回值的操作(比如Redis的SETNX)去set一個mutex key
當操作返回成功時,再進行load db的操作,并回設緩存,最后刪除mutex key;
當操作返回失敗,證明有線程在load db,當前線程睡眠一段時間再重試整個get緩存的方法。
可以對應的數據存在,但是key的數據已經過期(redis緩存過期,會自動刪除此key),此時大量的并發請求訪問不同的key,即同時大量的訪問不同的key,此時key處于過期階段,便會請求數據庫,大量的并發請求會壓垮數據庫服務器,這種情況被稱為緩存雪崩,和緩存擊穿的不同是前者是一個key。
緩存失效時的雪崩效應對底層系統的沖擊非常可怕!
(1) 構建多級緩存架構:
nginx緩存 + redis緩存 +其他緩存(ehcache等)
(2) 使用鎖或隊列:
用加鎖或者隊列的方式保證來保證不會有大量的線程對數據庫一次性進行讀寫,從而避免失效時大量的并發請求落到底層存儲系統上。不適用高并發情況
(3) 設置過期標志更新緩存:
記錄緩存數據是否過期(設置提前量),如果過期會觸發通知另外的線程在后臺去更新實際key的緩存。
(4) 將緩存失效時間分散開:
比如我們可以在原有的失效時間基礎上增加一個隨機值,比如1-5分鐘隨機,這樣每一個緩存的過期時間的重復率就會降低,就很難引發集體失效的事件。
到此,關于“基于Redis緩存數據常見的問題如何解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。