校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 淺談Redis 緩存的三大問題及其解決方案

淺談Redis 緩存的三大問題及其解決方案

熱門標簽:魔獸2青云地圖標注 貴州電銷卡外呼系統 宿遷便宜外呼系統平臺 北京400電話辦理收費標準 十堰營銷電銷機器人哪家便宜 日本中國地圖標注 山東外呼銷售系統招商 鄭州人工智能電銷機器人系統 超呼電話機器人

Redis 經常用于系統中的緩存,這樣可以解決目前 IO 設備無法滿足互聯網應用海量的讀寫請求的問題。

一、緩存穿透

緩存穿透是指緩存和數據庫中都沒有的數據,而用戶不斷發起請求,如發起 id 為-1 的數據或者特別大的不存在的數據。有可能是黑客利用漏洞攻擊從而去壓垮應用的數據庫。

1. 常見解決方案

對于緩存穿透問題,常見的解決方案有以下三種:

  • 驗證攔截:接口層進行校驗,如鑒定用戶權限,對 ID 之類的字段做基礎的校驗,如 id=0 的字段直接攔截;
  • 緩存空數據:當數據庫查詢到的數據為空時,也將這條數據進行緩存,但緩存的有效性設置得要較短,以免影響正常數據的緩存;
Copypublic Student getStudentsByID(Long id) {

// 從Redis中獲取學生信息
Student student = redisTemplate.opsForValue()
    .get(String.valueOf(id));
if (student != null) {
    return student;
}

// 從數據庫查詢學生信息,并存入Redis
student = studentDao.selectByStudentId(id);
if (student != null) {
    redisTemplate.opsForValue()
        .set(String.valueOf(id), student, 60, TimeUnit.MINUTES);
} else {
    // 即使不存在,也將其存入緩存中
    redisTemplate.opsForValue()
        .set(String.valueOf(id), null, 60, TimeUnit.SECONDS);
}

return student;

}

使用布隆過濾器:布隆過濾器是一種比較獨特數據結構,有一定的誤差。當它指定一個數據存在時,它不一定存在,但是當它指定一個數據不存在時,那么它一定是不存在的。

2. 布隆過濾器

布隆過濾器是一種比較特殊的數據結構,有點類似與 HashMap,在業務中我們可能會通過使用 HashMap 來判斷一個值是否存在,它可以在 O(1)時間復雜度內返回結果,效率極高,但是受限于存儲容量,如果可能需要去判斷的值超過億級別,那么 HashMap 所占的內存就很可觀了。

而 BloomFilter 解決這個問題的方案很簡單。首先用多個 bit 位去代替 HashMap 中的數組,這樣的話儲存空間就下來了,之后就是對 Key 進行多次哈希,將 Key 哈希后的值所對應的 bit 位置為 1。

當判斷一個元素是否存在時,就去判斷這個值哈希出來的比特位是否都為 1,如果都為 1,那么可能存在,也可能不存在(如下圖 F)。但是如果有一個 bit 位不為 1,那么這個 Key 就肯定不存在。

注意:BloomFilter 并不支持刪除操作,只支持添加操作。這一點很容易理解,因為你如果要刪除數據,就得將對應的 bit 位置為 0,但是你這個 Key 對應的 bit 位可能其他的 Key 也對應著。

3. 緩存空數據與布隆過濾器的比較

上面對這兩種方案都進行了簡單的介紹,緩存空數據與布隆過濾器都能有效解決緩存穿透問題,但使用場景有著些許不同;

  • 當一些惡意攻擊查詢查詢的 key 各不相同,而且數量巨多,此時緩存空數據不是一個好的解決方案。因為它需要存儲所有的 Key,內存空間占用高。并且在這種情況下,很多 key 可能只用一次,所以存儲下來沒有意義。所以對于這種情況而言,使用布隆過濾器是個不錯的選擇;
  • 而對與空數據的 Key 數量有限、Key 重復請求效率較高的場景而言,可以選擇緩存空數據的方案。

二、緩存擊穿

緩存擊穿是指當前熱點數據存儲到期時,多個線程同時并發訪問熱點數據。因為緩存剛過期,所有并發請求都會到數據庫中查詢數據。

解決方案

  • 將熱點數據設置為永不過期;
  • 加互斥鎖:互斥鎖可以控制查詢數據庫的線程訪問,但這種方案會導致系統的吞吐量下降,需要根據實際情況使用。
Copypublic String get(key) 
{
    String value = redis.get(key);
    if (value == null) 
    {
        // 代表緩存值過期 // 設置3min的超時,防止del操作失敗的時候,下次緩存過期一直不能
        load db if (redis.setnx(key_mutex, 1, 3 * 60) == 1) {
            // 代表設置成功
            value = db.get(key);
            redis.set(key, value, expire_secs);
            redis.del(key_mutex);
        }
        else {
            // 這個時候代表同時候的其他線程已經load db并回設到緩存了,這時候重試獲取緩存值即可
            sleep(50);
            get(key);
            // 重試
        }
    }
    else {
        return value;
    }
}

三、緩存雪崩

緩存雪崩發生有幾種情況,比如大量緩存集中在或者緩存同時在大范圍中失效,出現了大量請求去訪問數據庫,從而導致 CPU 和內存過載,甚至停機。

一個簡單的雪崩過程:

  1. Redis 集群產生了大面積故障;
  2. 緩存失敗,此時仍有大量請求去訪問 Redis 緩存服務器;
  3. 在大量 Redis 請求失敗后,這些請求將會去訪問數據庫;
  4. 由于應用的設計依賴于數據庫和 Redis 服務,很快就會造成服務器集群的雪崩,最終導致整個系統的癱瘓。

解決方案

  • 【事前】高可用緩存:高可用緩存是防止出現整個緩存故障。即使個別節點,機器甚至機房都關閉,系統仍然可以提供服務,Redis 哨兵(Sentinel) 和 Redis 集群(Cluster) 都可以做到高可用;
  • 【事中】緩存降級(臨時支持):當訪問次數急劇增加導致服務出現問題時,我們如何確保服務仍然可用。在國內使用比較多的是 Hystrix,它通過熔斷、降級、限流三個手段來降低雪崩發生后的損失。只要確保數據庫不死,系統總可以響應請求,每年的春節 12306 我們不都是這么過來的嗎?只要還可以響應起碼還有搶到票的機會;
  • 【事后】Redis 備份和快速預熱:Redis 數據備份和恢復、快速緩存預熱。

到此這篇關于淺談Redis 緩存的三大問題及其解決方案的文章就介紹到這了,更多相關Redis 緩存問題內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解Redis緩存穿透/擊穿/雪崩原理及其解決方案
  • java若依框架集成redis緩存詳解
  • Redis使用元素刪除的布隆過濾器來解決緩存穿透問題
  • 關于redisson緩存序列化的幾枚大坑說明
  • springboot使用Redis作緩存使用入門教程
  • 淺談java如何實現Redis的LRU緩存機制
  • 在項目中使用redis做緩存的一些思路

標簽:吉安 北京 朝陽 江蘇 果洛 臺州 大慶 楊凌

巨人網絡通訊聲明:本文標題《淺談Redis 緩存的三大問題及其解決方案》,本文關鍵詞  淺談,Redis,緩存,的,三,大問題,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談Redis 緩存的三大問題及其解決方案》相關的同類信息!
  • 本頁收集關于淺談Redis 緩存的三大問題及其解決方案的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产偷国产偷亚洲高清人白洁| 美女一区二区三区| 久久99久久久久| 91免费国产在线| 日韩视频免费观看高清完整版 | 日韩美女视频一区| 美女视频黄a大片欧美| 91蝌蚪porny| 久久蜜桃一区二区| 视频一区在线播放| 91色在线porny| 久久九九久久九九| 久久国产免费看| 欧美三级电影在线看| 亚洲欧洲日韩在线| 国产精品一卡二卡在线观看| 欧美一区二区在线不卡| 一区二区三区资源| www.欧美色图| 国产日产欧美一区| 国内久久精品视频| 日韩欧美激情四射| 美腿丝袜亚洲色图| 欧美高清你懂得| 午夜一区二区三区在线观看| 99精品欧美一区二区蜜桃免费 | 亚洲国产日韩一区二区| 成人国产精品免费网站| 久久久.com| 国产黄色成人av| 欧美国产精品中文字幕| 成人永久免费视频| 国产精品网友自拍| av在线这里只有精品| 国产拍揄自揄精品视频麻豆| 高清在线观看日韩| 国产精品国产精品国产专区不蜜 | 精品综合久久久久久8888| 制服丝袜亚洲播放| 男人操女人的视频在线观看欧美| 欧美日韩国产乱码电影| 天天色 色综合| 3d动漫精品啪啪一区二区竹菊| 日韩中文欧美在线| 日韩一区二区麻豆国产| 美女视频黄免费的久久| 久久久激情视频| 波多野结衣亚洲| 亚洲综合男人的天堂| 欧美一区中文字幕| 狠狠色狠狠色综合系列| 欧美极品另类videosde| 色8久久人人97超碰香蕉987| 亚洲777理论| 精品日韩一区二区| av不卡在线播放| 图片区小说区区亚洲影院| 日韩一区二区三区高清免费看看| 激情六月婷婷久久| 中文字幕一区在线观看视频| 欧美亚洲国产一区二区三区va | 国产成人福利片| 亚洲男人的天堂av| 日韩一区二区三区精品视频 | 欧美无砖专区一中文字| 老汉av免费一区二区三区| 国产精品毛片无遮挡高清| 欧美在线播放高清精品| 国产最新精品免费| 亚洲自拍偷拍图区| www国产成人| 91国产免费观看| 国产老妇另类xxxxx| 一区二区三区中文免费| 精品国产露脸精彩对白| 色一情一伦一子一伦一区| 麻豆精品在线观看| 亚洲一区二区欧美| 国产精品久久毛片| 4hu四虎永久在线影院成人| 成人av手机在线观看| 美女一区二区三区在线观看| 亚洲精品成a人| 国产亚洲欧洲997久久综合| 欧美精品亚洲二区| 99免费精品视频| 国产一区二区在线观看免费| 婷婷综合另类小说色区| 亚洲伦理在线精品| 日本一二三四高清不卡| 久久一夜天堂av一区二区三区| 欧洲视频一区二区| av电影在线不卡| 国产福利91精品一区二区三区| 欧美96一区二区免费视频| 一区二区三区欧美| 亚洲色图制服丝袜| 中文一区二区完整视频在线观看| 精品99999| 日韩欧美一卡二卡| 欧美一区日本一区韩国一区| 欧美影院一区二区| 欧美在线观看视频在线| 在线一区二区三区做爰视频网站| 成人一区二区三区视频| 国产精品影视天天线| 久久99蜜桃精品| 国内一区二区在线| 国产一区二区在线观看免费| 精品一区二区三区在线观看| 美腿丝袜亚洲色图| 激情五月播播久久久精品| 免费看日韩a级影片| 人妖欧美一区二区| 麻豆久久一区二区| 狠狠色综合播放一区二区| 韩国v欧美v日本v亚洲v| 国产精品资源站在线| 国产iv一区二区三区| 国产乱一区二区| 成人精品免费看| av在线不卡网| 在线日韩国产精品| 欧美日韩精品高清| 日韩一级在线观看| 亚洲精品在线三区| 国产欧美一区二区三区鸳鸯浴| 国产精品色哟哟网站| 亚洲精品免费在线观看| 亚洲国产精品一区二区久久恐怖片| 亚洲成人福利片| 麻豆成人av在线| 国产精品一区一区| 91麻豆免费看片| 欧美丰满一区二区免费视频| 日韩精品一区二区三区视频在线观看 | 国产精品中文字幕日韩精品| 国产成人av一区二区三区在线 | 一区二区免费看| 亚洲国产精品视频| 久久99久久99小草精品免视看| 国产精品99久久不卡二区| 97se狠狠狠综合亚洲狠狠| 色婷婷精品久久二区二区蜜臀av | 久久精品夜色噜噜亚洲a∨| 国产精品夫妻自拍| 午夜精品123| 丁香网亚洲国际| 欧美视频日韩视频| 久久婷婷色综合| 一区二区成人在线观看| 国产一区在线不卡| 欧美日韩国产首页| 国产亚洲一二三区| 亚洲成va人在线观看| 国产精品一区一区三区| 欧美日韩精品高清| 中文字幕一区二区视频| 免费观看30秒视频久久| 91在线丨porny丨国产| 精品国产乱码久久久久久浪潮| 亚洲黄色片在线观看| 国产在线精品不卡| 欧美日韩综合一区| 中文字幕制服丝袜成人av| 美腿丝袜在线亚洲一区| 欧亚一区二区三区| 国产精品欧美一区喷水| 久久99国产精品久久99果冻传媒| 91黄视频在线| 国产精品女同互慰在线看| 精品一区二区久久久| 在线视频欧美精品| 亚洲欧美综合网| 成av人片一区二区| 久久精品人人爽人人爽| 久久疯狂做爰流白浆xx| 在线播放/欧美激情| 亚洲风情在线资源站| 99视频在线精品| 日本一二三四高清不卡| 国产麻豆午夜三级精品| 日韩欧美黄色影院| 日本不卡高清视频| 欧美福利电影网| 丝袜美腿亚洲综合| 91麻豆精品国产91久久久久| 亚洲国产一区二区在线播放| 一本大道久久a久久精二百| 中文字幕制服丝袜一区二区三区 | 国产69精品久久99不卡| 久久久一区二区| 国产另类ts人妖一区二区| 国产色一区二区| 国产精品中文字幕一区二区三区| 国产网站一区二区| 精品在线你懂的| 欧美成人性福生活免费看| 美女在线一区二区| 久久蜜桃av一区二区天堂|