亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于Redis緩存數(shù)據(jù)常見的三種問題及解決

 更新時間:2022年06月16日 14:19:51   作者:道上叫我盧鐵柱  
這篇文章主要介紹了基于Redis緩存數(shù)據(jù)常見的三種問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

1.緩存穿透

1.1 問題描述

緩存穿透是在客戶端/瀏覽器端請求一個不存在的key,這個key在redis中不存在,在數(shù)據(jù)庫中也不存在數(shù)據(jù)源,每次對此key的請求從緩存獲取不到,就會請求數(shù)據(jù)源。

如使用一個不存在的用戶id去訪問用戶信息,redis和數(shù)據(jù)庫中都沒有,多次進行請求可能會壓垮數(shù)據(jù)源

1.2 解決方法

一個一定不存在緩存及查詢不到的數(shù)據(jù),由于緩存是不命中時被動寫入的,緩存不存在,出于容錯考慮,查詢不到的數(shù)據(jù)是不會緩存在redis當中,這將導致每次請求不存在的數(shù)據(jù)都會請求數(shù)據(jù)庫,失去了緩存的意義。

(1)如果一個查詢返回的數(shù)據(jù)為空(不管是數(shù)據(jù)是否不存在),我們仍然把這個空結果(null)進行緩存,設置空結果的過期時間會很短,最長不超過五分鐘

(2)設置可訪問的名單(白名單):使用bitmaps類型定義一個可以訪問的名單,名單id作為bitmaps的偏移量,每次訪問和bitmap里面的id進行比較,如果訪問id不在bitmaps里面,進行攔截,不允許訪問。

(3)采用布隆過濾器

(4)進行實時的數(shù)據(jù)監(jiān)控,發(fā)現(xiàn)Redis在命中率急速降低時,排查訪問對象和訪問數(shù)據(jù),設置黑名單。

2.緩存擊穿

2.1 問題描述

當用戶請求一個存在的key的數(shù)據(jù)時,此時redis中該key的數(shù)據(jù)已經(jīng)過時,此時若有大量并發(fā)請求發(fā)現(xiàn)緩存過期都會請求數(shù)據(jù)源加載數(shù)據(jù)并且緩存到redis當中,這個時候大量的并發(fā)可能會把數(shù)據(jù)庫服務壓垮。

2.2 解決方法

key可能在某一個時間段被大量的請求,這個key的數(shù)據(jù)被稱為熱點數(shù)據(jù),這個時候便要考慮“擊穿”問題。

(1)預先設置熱門數(shù)據(jù):在redis高峰訪問之前,把一些熱門數(shù)據(jù)提前存入到redis里面,加大這些熱門數(shù)據(jù)key的時長

(2)實時調整:現(xiàn)場監(jiān)控哪些數(shù)據(jù)熱門,實時調整key的過期時長

(3)使用鎖:

  • 就是在緩存失效的時候(判斷拿出來的值為空),不是立即去load db。
  • 先使用緩存工具的某些帶成功操作返回值的操作(比如Redis的SETNX)去set一個mutex key
  • 當操作返回成功時,再進行l(wèi)oad db的操作,并回設緩存,最后刪除mutex key;
  • 當操作返回失敗,證明有線程在load db,當前線程睡眠一段時間再重試整個get緩存的方法。

3.緩存雪崩

3.1 問題描述

可以對應的數(shù)據(jù)存在,但是key的數(shù)據(jù)已經(jīng)過期(redis緩存過期,會自動刪除此key),此時大量的并發(fā)請求訪問不同的key,即同時大量的訪問不同的key,此時key處于過期階段,便會請求數(shù)據(jù)庫,大量的并發(fā)請求會壓垮數(shù)據(jù)庫服務器,這種情況被稱為緩存雪崩,和緩存擊穿的不同是前者是一個key。

3.2 解決方法

緩存失效時的雪崩效應對底層系統(tǒng)的沖擊非常可怕!

(1) 構建多級緩存架構:

  • nginx緩存 + redis緩存 +其他緩存(ehcache等)

(2) 使用鎖或隊列:

  • 用加鎖或者隊列的方式保證來保證不會有大量的線程對數(shù)據(jù)庫一次性進行讀寫,從而避免失效時大量的并發(fā)請求落到底層存儲系統(tǒng)上。不適用高并發(fā)情況

(3) 設置過期標志更新緩存:

  • 記錄緩存數(shù)據(jù)是否過期(設置提前量),如果過期會觸發(fā)通知另外的線程在后臺去更新實際key的緩存。

(4) 將緩存失效時間分散開:

  • 比如我們可以在原有的失效時間基礎上增加一個隨機值,比如1-5分鐘隨機,這樣每一個緩存的過期時間的重復率就會降低,就很難引發(fā)集體失效的事件。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關文章

  • redis.conf中使用requirepass不生效的原因及解決方法

    redis.conf中使用requirepass不生效的原因及解決方法

    本文主要介紹了如何啟用requirepass,以及啟用requirepass為什么不會生效,從代碼層面分析了不生效的原因,以及解決方法,需要的朋友可以參考下
    2023-07-07
  • Redis客戶端及服務端的安裝教程詳解

    Redis客戶端及服務端的安裝教程詳解

    這篇文章主要介紹了Redis客戶端及服務端的安裝教程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Redis分布式限流組件設計與使用實例

    Redis分布式限流組件設計與使用實例

    本文主要講解基于 自定義注解+Aop+反射+Redis+Lua表達式 實現(xiàn)的限流設計方案。實現(xiàn)的限流設計與實際使用。具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Redis解決庫存超賣問題實例講解

    Redis解決庫存超賣問題實例講解

    這篇文章主要介紹了Redis解決庫存超賣問題實例講解,問題和解決辦法都列舉了出來,很貼合實際開發(fā)場景,有需要的同學可以學習下
    2021-03-03
  • redis中使用java腳本實現(xiàn)分布式鎖

    redis中使用java腳本實現(xiàn)分布式鎖

    這篇文章主要介紹了redis中使用java腳本實現(xiàn)分布式鎖,本文同時講解了java腳本和lua腳本實現(xiàn)分布式鎖,需要的朋友可以參考下
    2015-01-01
  • 一文弄懂Redis 線程模型

    一文弄懂Redis 線程模型

    使用Redis 時,幾乎不存在 CPU 成為瓶頸的情況, Redis 主要受限于內存和網(wǎng)絡 使用了單線程后,可維護性高,感興趣的可以了解一下
    2024-02-02
  • Redis實現(xiàn)分布式鎖和等待序列的方法示例

    Redis實現(xiàn)分布式鎖和等待序列的方法示例

    這篇文章主要介紹了Redis實現(xiàn)分布式鎖和等待序列的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • 詳解Redis 數(shù)據(jù)類型

    詳解Redis 數(shù)據(jù)類型

    這篇文章主要介紹了Redis 數(shù)據(jù)類型的相關資料,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-08-08
  • 分布式架構Redis中有哪些數(shù)據(jù)結構及底層實現(xiàn)原理

    分布式架構Redis中有哪些數(shù)據(jù)結構及底層實現(xiàn)原理

    這篇文章主要為大家介紹了分布式架構Redis中有哪些數(shù)據(jù)結構及底層的實現(xiàn)原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-03-03
  • Redis教程(一):Redis簡介

    Redis教程(一):Redis簡介

    這篇文章主要介紹了Redis教程(一):Redis簡介,本文是系列文章的第一篇,歡迎大家跟隨本教程學習Redis數(shù)據(jù)庫,需要的朋友可以參考下
    2015-04-04

最新評論