zooKeeper基礎(chǔ)(二)

ZooKeeper是一個分布式協(xié)調(diào)系統(tǒng),應用廣泛捏鱼,其功能有:
服務發(fā)現(xiàn)
配置管理
分布式鎖
分布式領(lǐng)導選舉
zookeeper是一個樹形結(jié)構(gòu)蒙畴,類似Linux的文件系統(tǒng),對每個節(jié)點提供監(jiān)控和通知的機制榴啸。

zookeeper集群是基于主從復制的孽惰,每個服務器可能有三種角色之一:
Leader
Follower
Observer
一個集群在同一時間,只能有一個實際工作的Leader鸥印,它會發(fā)起和維護與各Follower和Observer之間的心跳勋功。

所有的寫操作必須通過Leader完成,再由Leader將寫操作廣播給其他服務器库说。只要有超過半數(shù)節(jié)點(不包含observer節(jié)點)寫入成功狂鞋,該寫請求就會被提交。(類似2PC協(xié)議)

一個zookeeper可能存在多個follower潜的,它會響應Leader的心跳骚揍。follower可以直接處理并返回客戶端的讀請求,同時會將寫請求轉(zhuǎn)發(fā)給Leader處理夏块,并且負責在Leader處理寫請求時疏咐,對請求進行投票。

角色與follower類似脐供,但是無權(quán)發(fā)起投票浑塞。zookeeper需要保證高可用行和強一致性,為了支持更多的客戶端政己,需要很多server酌壕,但是server多了以后掏愁,投票階段的延遲增大,會影響性能卵牍,基于這種考慮才會引入observer這種角色果港。Observers可以接受客戶端的連接,并將寫請求轉(zhuǎn)發(fā)給Leader節(jié)點糊昙,這樣就提高了伸縮性辛掠,但不會降低吞吐率。


zookeeper的核心是原子廣播(Atomic Broadcast)释牺,這個機制保證了各個server之間的同步萝衩。實現(xiàn)這個機制的協(xié)議叫做Zab協(xié)議,這個協(xié)議有兩種模式:恢復模式和廣播模式没咙。

當服務啟動或者Leader崩潰后猩谊,Zab就會進入恢復模式,當Leader被選舉出來祭刚,且Leader完成和大多數(shù)server的狀態(tài)同步之后牌捷,恢復模式就會結(jié)束。這個時候涡驮,Zab就會進入廣播模式暗甥。

如果一個新的server加入到zookeeper中,它會在回復模式下啟動捉捅,發(fā)現(xiàn)Leader淋袖,并和Leader進行狀態(tài)同步,然后也會參加消息廣播锯梁。

zookeeper服務會一直維持在broadcast狀態(tài),知道Leader崩潰或者失去大多數(shù)followers的支持焰情。

廣播模式下陌凳,要保證所有提議(proposal)要按照順序處理,所以所有proposal都在被提出的時候加上了事務id(zxid)内舟,且zxid是遞增的合敦。

zxid是一個64位的數(shù)字,高32位表示紀元(epoch)验游,當選舉出一個新的Leader時充岛,epoch會加1,低32位清零耕蝉。低32位是一個遞增的計數(shù)器崔梗。

具體問題:Leader是怎樣被選舉出來的?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末垒在,一起剝皮案震驚了整個濱河市蒜魄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖谈为,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旅挤,死亡現(xiàn)場離奇詭異,居然都是意外死亡伞鲫,警方通過查閱死者的電腦和手機粘茄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來秕脓,“玉大人柒瓣,你說我怎么就攤上這事∪龌幔” “怎么了嘹朗?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長诵肛。 經(jīng)常有香客問我屹培,道長,這世上最難降的妖魔是什么怔檩? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任褪秀,我火速辦了婚禮,結(jié)果婚禮上薛训,老公的妹妹穿的比我還像新娘媒吗。我一直安慰自己,他們只是感情好乙埃,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布闸英。 她就那樣靜靜地躺著,像睡著了一般介袜。 火紅的嫁衣襯著肌膚如雪甫何。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天遇伞,我揣著相機與錄音辙喂,去河邊找鬼。 笑死鸠珠,一個胖子當著我的面吹牛巍耗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播渐排,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼炬太,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了驯耻?” 一聲冷哼從身側(cè)響起娄琉,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤次乓,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后孽水,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體票腰,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年女气,在試婚紗的時候發(fā)現(xiàn)自己被綠了杏慰。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡炼鞠,死狀恐怖缘滥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情谒主,我是刑警寧澤朝扼,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站霎肯,受9級特大地震影響擎颖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜观游,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一搂捧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧懂缕,春花似錦允跑、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至工碾,卻和暖如春潮针,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背倚喂。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瓣戚,地道東北人端圈。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像子库,于是被迫代替她去往敵國和親舱权。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容