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

redis數(shù)據(jù)傾斜處理方法

 更新時(shí)間:2022年12月20日 11:38:54   作者:wang0907  
我們在使用Redis分片集群時(shí),集群最好的狀態(tài)就是每個(gè)實(shí)例可以處理相同或相近比例的請求,但如果不是這樣,則會(huì)出現(xiàn)某些實(shí)例壓力特別大,而某些實(shí)例特別空閑的情況發(fā)生,本文就一起來看下這種情況是如何發(fā)生的以及如何處理

寫在前面

我們在使用Redis分片集群時(shí),集群最好的狀態(tài)就是每個(gè)實(shí)例可以處理相同或相近比例的請求,但如果不是這樣,則會(huì)出現(xiàn)某些實(shí)例壓力特別大,而某些實(shí)例特別空閑的情況發(fā)生,本文就一起來看下這種情況是如何發(fā)生的以及如何處理。

1:什么是數(shù)據(jù)傾斜

數(shù)據(jù)傾斜分為兩種,第一種是數(shù)據(jù)量傾斜,第二種是數(shù)據(jù)訪問傾斜,定義如下:

  • 數(shù)據(jù)量傾斜:數(shù)據(jù)分布的不均勻,導(dǎo)致某些實(shí)例數(shù)據(jù)特別多,進(jìn)而導(dǎo)致處理的請求量大
  • 數(shù)據(jù)訪問傾斜:數(shù)據(jù)分布均勻,但是某些實(shí)例存在熱點(diǎn)數(shù)據(jù),進(jìn)而導(dǎo)致處理的請求量大

可以看到不管是數(shù)據(jù)量傾斜,還是數(shù)據(jù)訪問傾斜,最終導(dǎo)致的結(jié)果都是發(fā)生傾斜的實(shí)例處理了更多的數(shù)據(jù)請求,壓力增大。

2:數(shù)據(jù)量傾斜

在這里插入圖片描述

數(shù)據(jù)量傾斜最常見的原因就是在手動(dòng)劃分slot時(shí),分配不均勻,除此之外,還有big key,hash tag,分別來看下。

2.1:slot分配不均勻

slot分配不均勻一般是由于手動(dòng)分配造成,或者是因?yàn)槟硞€(gè)實(shí)例節(jié)點(diǎn)配置較高,為了更加充分的利用其計(jì)算機(jī)資源,有意的給其分配更多的slot,但是這個(gè)多出的量其實(shí)是不好預(yù)估的,所以對于因?yàn)橛?jì)算機(jī)性能差異有意分配的造成的slot不均勻還是要盡量避免,即保證所有的實(shí)例節(jié)點(diǎn)都具有相同的配置,然后將slot進(jìn)行均勻分配。如果是已經(jīng)發(fā)生了slot分配不均勻,我們可以通過遷移slot的方式來處理,首先通過cluster slots命令查看當(dāng)前slot的分配情況:

在這里插入圖片描述

上圖slot0~4095分配到了實(shí)例192.168.10.3:6379,slot12288~16383分配到了實(shí)例192.168.10.5:6379。如下是一個(gè)slot遷移的例子。

假設(shè)我們要把 Slot 300 從源實(shí)例(ID 為 3)遷移到目標(biāo)實(shí)例(ID 為 5),那要怎么做呢?

第1步,我們先在目標(biāo)實(shí)例5上執(zhí)行下面的命令,將Slot 300的源實(shí)例設(shè)置為實(shí)例 3,表示要從實(shí)例 3 上遷入 Slot 300。

在這里插入圖片描述

第2步,在源實(shí)例 3 上,我們把 Slot 300 的目標(biāo)實(shí)例設(shè)置為 5,這表示,Slot 300 要遷出到實(shí)例 5 上,如下所示:

在這里插入圖片描述

第3步,從 Slot 300 中獲取 100 個(gè) key。因?yàn)?Slot 中的 key 數(shù)量可能很多,所以我們需要在客戶端上多次執(zhí)行下面的這條命令,分批次獲得并遷移 key。

在這里插入圖片描述

第4步,我們把剛才獲取的 100 個(gè) key 中的 key1 遷移到目標(biāo)實(shí)例 5 上(IP 為 192.168.10.5),同時(shí)把要遷入的數(shù)據(jù)庫設(shè)置為 0 號(hào)數(shù)據(jù)庫,把遷移的超時(shí)時(shí)間設(shè)置為 timeout。我們重復(fù)執(zhí)行 MIGRATE 命令,把 100 個(gè) key 都遷移完。

在這里插入圖片描述

最后,我們重復(fù)執(zhí)行第 3 和第 4 步,直到 Slot 中的所有 key 都遷移完成。

從Redis3.0.6開始,你也可以使用KEYS選項(xiàng),一次遷移多個(gè)key(key1、2、3),這樣可以提升遷移效率。

在這里插入圖片描述

2.2:big key

bigkey,主要包括string的值特別大,和集合類型的元素特別多兩種情況,對于string,我們需要在業(yè)務(wù)上處理,分散到多個(gè)key存儲(chǔ),然后在業(yè)務(wù)上多次獲取,并進(jìn)行合并,比如如下劃分:

key:
    names
劃分為
key:
    name:1_1000 ... name:100001_101001 

其實(shí)這里是用到了分片的思想,對于集合的處理方式和string也是類似的,比如有一個(gè)包含100萬個(gè)元素的hash集合user:info,分片存儲(chǔ)后如下:

key: 
    user:info
key: 
    user:info:1_100000,user:info:100001_20000,...,user:info:900001_1000000

對于bigkey我們還是要在業(yè)務(wù)上盡量避免,因?yàn)閎igkey的副作用不僅僅如此,還有如數(shù)據(jù)同步慢,數(shù)據(jù)恢復(fù)慢,刪除慢等。

2.3:hash tag

我們正常設(shè)置key,計(jì)算其slot值的方式是crc16(key)%16384,但是如果是使用了{},比如keypart1:{keypart2},則計(jì)算的邏輯就變成了crc16(keypart2)%16384,一般用在希望某幾類key分布到同一個(gè)實(shí)例,進(jìn)而可以方便的進(jìn)行某些操作的場景,如事務(wù),簡單的計(jì)算等,但是一般帶來的的負(fù)面影響要比收益大的多,比如造成這里分析的數(shù)據(jù)傾斜問題,數(shù)據(jù)傾斜影響的是整個(gè)Redis實(shí)例,影響更大,所以在實(shí)踐中要盡量避免使用hash tag。

3:數(shù)據(jù)訪問傾斜

在這里插入圖片描述

數(shù)據(jù)訪問傾斜出現(xiàn)的場景一般就是熱點(diǎn)數(shù)據(jù),比如首頁的新聞,某明星出軌離婚等爆點(diǎn)新聞,對于這類問題一般有如下的解決方法:

1:拷貝幾份數(shù)據(jù),以分散到不同的實(shí)例
    比如news:1,可以虛擬出幾份數(shù)據(jù),如news:1:A,news:1:B,...news:1:Z,客戶端訪問時(shí)隨機(jī)的增加A~Z的后綴,分散壓力,這種方法可以用于只讀的熱點(diǎn)數(shù)據(jù)
2:增加機(jī)器配置
    這種方法是針對讀寫數(shù)據(jù),因?yàn)槿绻前凑辗桨?,數(shù)據(jù)的一致性將會(huì)帶來額外的性能開銷,以及更多潛在的bug。

到此這篇關(guān)于redis之?dāng)?shù)據(jù)傾斜如何處理的文章就介紹到這了,更多相關(guān)redis數(shù)據(jù)傾斜內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 內(nèi)存型數(shù)據(jù)庫Redis持久化小結(jié)

    內(nèi)存型數(shù)據(jù)庫Redis持久化小結(jié)

    redis是一個(gè)支持持久化的內(nèi)存數(shù)據(jù)庫,也就是說redis需要經(jīng)常將內(nèi)存中的數(shù)據(jù)同步到磁盤來保證持久化.redis支持四種持久化方式,一是 Snapshotting(快照)也是默認(rèn)方式,二是Append-only file(縮寫aof)的方式,三是虛擬內(nèi)存方式,四是diskstore方式.今天我們總結(jié)下前2種。
    2017-09-09
  • Redis慢查詢的具體使用

    Redis慢查詢的具體使用

    慢查詢顧名思義就是比較慢的查詢,但是究竟是哪里慢呢?本文詳細(xì)的介紹了Redis慢查詢的具體使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-06-06
  • Redis異步隊(duì)列的實(shí)現(xiàn)及應(yīng)用場景

    Redis異步隊(duì)列的實(shí)現(xiàn)及應(yīng)用場景

    異步隊(duì)列是一種底層基于異步 I/O 模型的消息隊(duì)列,用于在分布式系統(tǒng)中進(jìn)行同步和異步的通訊和協(xié)作,本文主要介紹了Redis異步隊(duì)列的實(shí)現(xiàn)及應(yīng)用場景,感興趣的可以了解一下
    2023-12-12
  • 簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法

    簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法

    這里我們來講解一個(gè)簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法,有一個(gè)在不同主機(jī)上遷移Redis數(shù)據(jù)的示例,還有一個(gè)備份腳本實(shí)現(xiàn)的關(guān)鍵點(diǎn)提示,一起來看一下:
    2016-06-06
  • 關(guān)于redis Key淘汰策略的實(shí)現(xiàn)方法

    關(guān)于redis Key淘汰策略的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄P(guān)于redis Key淘汰策略的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • Java實(shí)現(xiàn)多級緩存的方法詳解

    Java實(shí)現(xiàn)多級緩存的方法詳解

    對于高并發(fā)系統(tǒng)來說,有三個(gè)重要的機(jī)制來保障其高效運(yùn)行,它們分別是:緩存、限流和熔斷,所以本文就來和大家探討一下多級緩存的實(shí)現(xiàn)方法,希望對大家有所幫助
    2024-02-02
  • Redis連接池配置及初始化實(shí)現(xiàn)

    Redis連接池配置及初始化實(shí)現(xiàn)

    這篇文章主要介紹了Redis連接池配置及初始化實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Redis過期時(shí)間的設(shè)計(jì)與實(shí)現(xiàn)代碼

    Redis過期時(shí)間的設(shè)計(jì)與實(shí)現(xiàn)代碼

    在?Redis?中,鍵的過期時(shí)間設(shè)計(jì)與實(shí)現(xiàn)是一個(gè)重要的功能,這使得?Redis?可以自動(dòng)刪除在指定時(shí)間后不再需要的鍵,下面詳細(xì)介紹?Redis?過期時(shí)間的設(shè)計(jì)和實(shí)現(xiàn),包括設(shè)置過期時(shí)間、過期鍵的存儲(chǔ)結(jié)構(gòu)、過期鍵的刪除策略等,需要的朋友可以參考下
    2024-08-08
  • Redis安裝啟動(dòng)及常見數(shù)據(jù)類型

    Redis安裝啟動(dòng)及常見數(shù)據(jù)類型

    這篇文章主要介紹了Redis安裝啟動(dòng)及常見數(shù)據(jù)類型,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • 深入理解Redis內(nèi)存回收和內(nèi)存淘汰機(jī)制

    深入理解Redis內(nèi)存回收和內(nèi)存淘汰機(jī)制

    Redis使用多種過期策略和內(nèi)存淘汰機(jī)制來管理內(nèi)存,本文主要介紹了深入理解Redis內(nèi)存回收和內(nèi)存淘汰機(jī)制, 具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06

最新評論