分割超大Redis數(shù)據(jù)庫(kù)例子
薄荷 App 上的伙伴功能大量使用了內(nèi)存數(shù)據(jù)庫(kù) Redis,隨著數(shù)據(jù)量的快速增長(zhǎng),Redis 膨脹得很快,已經(jīng)接近 12 GB規(guī)模,這些數(shù)據(jù)全部放在單個(gè) Redis 實(shí)例中。單個(gè)巨大 Redis 實(shí)例有如下幾個(gè)壞處:
1.首先,需要一臺(tái)內(nèi)存很大的機(jī)器。Redis 是內(nèi)存數(shù)據(jù)庫(kù),它需要把所有需求全部放在內(nèi)存中,需要為之裝下 12 GB的 Redis 實(shí)例,至少需要 12 GB 內(nèi)存大小的機(jī)器,考慮的預(yù)留增長(zhǎng)空間,一般需要 12 * 1.5 約 18 GB 內(nèi)存。 另外還有一個(gè)考慮的因素是,Redis 進(jìn)行硬盤數(shù)據(jù)存儲(chǔ)時(shí),fork 進(jìn)程需要消耗同樣大小的內(nèi)存,因此一個(gè) 12GB 的 redis 實(shí)例需要 32 GB左右的內(nèi)存比較合適,這對(duì)機(jī)器提出了很高的要求,常常難以滿足。
2.然后,Redis 容易成為性能瓶頸。Redis 的并發(fā)模型是單進(jìn)程單線程,它不能充分利用多核 CPU,在請(qǐng)求數(shù)很高,或者某一些請(qǐng)求處理比較慢時(shí)(比如一些大的數(shù)據(jù)排序),可能會(huì)成為系統(tǒng)的性能瓶頸。有方法可以緩解甚至這個(gè)問(wèn)題,就是建立多個(gè) Redis 實(shí)例,通過(guò)多個(gè) Redis 連接來(lái)實(shí)現(xiàn)。
3.另外,單個(gè)巨大的 Redis 實(shí)例也會(huì)增加數(shù)據(jù)管理難度,因?yàn)檫@么大的數(shù)據(jù)量,無(wú)論是復(fù)制,備份操作都比較慢,容易對(duì)線上系統(tǒng)造成沖擊。
因此,十分有必要把單個(gè)巨大的 Redis 實(shí)例分割成多個(gè)小的 Redis 實(shí)例。
使用 Redis 的復(fù)制機(jī)制,可以在線平滑處理 Redis 實(shí)例分割,幾乎不會(huì)對(duì)系統(tǒng)有很大的影響。
分割的具體操作思路如下:
1.首先,規(guī)劃 Redis 分割策略,通常是基于業(yè)務(wù)劃分,比如薄荷伙伴是基于業(yè)務(wù)分成 timeline, user_relationship, other 3個(gè) Redis 實(shí)例。規(guī)劃好之后,需要根據(jù)規(guī)劃結(jié)果對(duì)應(yīng)用程序中 Redis 程序代碼做修改,通常是有一個(gè)統(tǒng)一的 Redis 鏈接修改為多個(gè) Redis 連接,不同業(yè)務(wù)使用不同的連接。
2.然后,通過(guò) Redis 復(fù)制功能建立多個(gè) Redis 副本,讓不同 Redis 連接使用不同的 Redis 副本,在 Redis 副本中刪除多余的數(shù)據(jù)。批量刪除某個(gè)模式的 keys,可以使用下面的 shell 命令:
redis-cli KEYS "<pattern>" | xargs redis-cli DEL
改成實(shí)際的模式,如
redis-cli KEYS "user:*:followers" | xargs redis-cli DEL
表示刪除 user followers 數(shù)據(jù)。
最后通過(guò)來(lái)回切換并重啟 Redis 實(shí)例達(dá)到完全分割 Redis 實(shí)例。
相關(guān)文章
redis實(shí)現(xiàn)分布式session的解決方案
session存放在服務(wù)器,關(guān)閉瀏覽器不會(huì)失效,本文主要介紹了redis實(shí)現(xiàn)分布式session的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03Redis數(shù)據(jù)結(jié)構(gòu)之intset整數(shù)集合使用學(xué)習(xí)
這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之整數(shù)集合使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07redis中redisson實(shí)現(xiàn)鎖自動(dòng)延時(shí)
redisson作為分布式鎖能夠解決分布式的加鎖解鎖問(wèn)題,還能夠?qū)崿F(xiàn)鎖的設(shè)置存活時(shí)間以及自動(dòng)續(xù)期,本文主要介紹了redis中redisson實(shí)現(xiàn)鎖自動(dòng)延時(shí),感興趣的可以了解一下2024-02-02Redis String 類型和 Hash 類型學(xué)習(xí)筆記與總結(jié)
這篇文章主要介紹了Redis String 類型和 Hash 類型學(xué)習(xí)筆記與總結(jié),本文分別對(duì)String 類型的一些方法和Hash 類型做了詳細(xì)介紹,需要的朋友可以參考下2015-06-06Redis不同數(shù)據(jù)類型使用場(chǎng)景代碼實(shí)例
這篇文章主要介紹了Redis不同數(shù)據(jù)類型使用場(chǎng)景代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12Redis server 主從復(fù)制配置實(shí)現(xiàn)
從復(fù)制是指將一個(gè)Redis服務(wù)器的數(shù)據(jù)復(fù)制到其他Redis服務(wù)器的過(guò)程,本文主要介紹了Redis server 主從復(fù)制配置實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02