redis cluster多master架構

redis cluster概述

  • redis cluster提供了多個master節(jié)點喇闸,數(shù)據(jù)可以存儲在多個master節(jié)點上可缚;
  • 每個master都有一個slave,配置成讀寫分離
  • 如果一個master發(fā)生故障匪蟀,就會自動將其slave切換成master

redis cluster的基本功能簡介

1提岔、多master寫入實現(xiàn)海量數(shù)據(jù)的分布式存儲

  • 在redis cluster寫入數(shù)據(jù)的時候,其實是將請求發(fā)送到任意一個master上去執(zhí)行主巍。
  • 每個master都需要計算這個key對應的CRC16值冠息,然后對16384個hashslot取模,從而找到該key對應的hashslot孕索,以及hashslot對應的master逛艰。
  • 如果對應的master就在本服務器master上,執(zhí)行命令set mykey1 v1后搞旭,mykey1這個key對應的hashslot就在本服務器master上自己處理了散怖。
  • 如果計算出來的hashslot在其他master上菇绵,那么就會給客戶端返回一個moved error,讓客戶端去其他master上去執(zhí)行這條命令镇眷。

多master寫入

多master寫入涉及分布式的數(shù)據(jù)存儲咬最,每條數(shù)據(jù)只能存在于一個master上,不同的master負責存儲不同的數(shù)據(jù)欠动。
如果100w條數(shù)據(jù)寫入到5個master永乌,那么每個master就只需負責存儲20w條數(shù)據(jù)。
redis cluster可以寫到任意master具伍,任意master計算key的hashslot以后翅雏,通知client重定向路由到其他mater去執(zhí)行,這就是分布式存儲的一個經(jīng)典的做法人芽。

多master讀寫分離

在redis cluster多master讀寫分離架構中望几,如果要在slave中 讀取數(shù)據(jù),那么需要readonly指令萤厅。

redis-cli -h 192.168.201.34 -p 7004
get mykey1
(error) MOVED 1860 192.168.201.33:7001
192.168.201.34:7004> readonly
OK
192.168.201.34:7004> get mykey1
"111"

redis-cli -c啟動橄妆,就會自動進行各種底層的重定向的操作

redis-cli -h 192.168.201.33 -p 7001 -c
192.168.201.33:7001> set mykey6 666
-> Redirected to slot [14243] located at 192.168.201.35:7005
OK
192.168.201.35:7005> get mykey6
"666"

redis cluster讀寫分離架構的限制性:

  • 默認情況下,redis cluster核心理念就是用slave做高可用祈坠,每個master掛一兩個slave,主要負責數(shù)據(jù)的熱備矢劲,以及master故障時的主備切換赦拘;
  • redis cluster默認不支持slave節(jié)點讀和寫的,這跟基于replication搭建的主從架構不一樣:
    因此芬沉,在slave節(jié)點上設置readonly指令躺同,才能執(zhí)行get命令在slave node進行讀取丸逸;
  • redis cluster支持主從架構蹋艺,也可以做讀寫分離但是比較復雜。jedis客戶端對redis cluster的讀寫分離支持不是太好黄刚;
  • 默認的話就是讀和寫都到master上去執(zhí)行捎谨;
  • 如果jedis做redis cluster讀寫分離的處理,需要修改一下jedis的源碼:做一個redis cluster的讀寫分離的訪問api憔维。

總結

綜上所述涛救,redis cluster已經(jīng)沒有讀寫分離的概念:

  • 首先,讀寫分離通過建立一主多從的架構业扒,橫向任意擴展slave節(jié)點去支撐高并發(fā)的讀吞吐量检吆;
  • 但是在redis cluster的架構下,master節(jié)點是可以任意擴展的程储,如果要支撐更大的讀寫吞吐量蹭沛,只需要對master節(jié)點進行橫向擴展臂寝。
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市摊灭,隨后出現(xiàn)的幾起案子咆贬,更是在濱河造成了極大的恐慌,老刑警劉巖斟或,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件素征,死亡現(xiàn)場離奇詭異,居然都是意外死亡萝挤,警方通過查閱死者的電腦和手機御毅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來怜珍,“玉大人端蛆,你說我怎么就攤上這事∷址海” “怎么了今豆?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長柔袁。 經(jīng)常有香客問我呆躲,道長,這世上最難降的妖魔是什么捶索? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任插掂,我火速辦了婚禮,結果婚禮上腥例,老公的妹妹穿的比我還像新娘辅甥。我一直安慰自己,他們只是感情好燎竖,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布璃弄。 她就那樣靜靜地躺著,像睡著了一般构回。 火紅的嫁衣襯著肌膚如雪夏块。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天纤掸,我揣著相機與錄音拨扶,去河邊找鬼。 笑死茁肠,一個胖子當著我的面吹牛患民,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播垦梆,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼匹颤,長吁一口氣:“原來是場噩夢啊……” “哼仅孩!你這毒婦竟也來了?” 一聲冷哼從身側響起印蓖,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤辽慕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后赦肃,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體溅蛉,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年他宛,在試婚紗的時候發(fā)現(xiàn)自己被綠了船侧。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡厅各,死狀恐怖镜撩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情队塘,我是刑警寧澤袁梗,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站憔古,受9級特大地震影響遮怜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鸿市,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一奈泪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧灸芳,春花似錦、人聲如沸拜姿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蕊肥。三九已至谒获,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間壁却,已是汗流浹背批狱。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留展东,地道東北人赔硫。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像盐肃,于是被迫代替她去往敵國和親爪膊。 傳聞我的和親對象是個殘疾皇子权悟,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354