Zookeeper選舉機制

前言

Zookeeper為了保證各節(jié)點的協(xié)同工作朦肘,在工作時需要一個Leader角色灯抛,而Zookeerper默認采用FastLeaderElection算法,且投票數(shù)大于半數(shù)則勝出的機制。

相關概念

  • 服務器ID
    這是在配置集群時設置的myid參數(shù)文件嫉鲸,且參數(shù)分別表示為服務器1、服務器2、服務器3次慢,編號越大在FastLeaderElection算法的權(quán)重越大。
  • 選舉狀態(tài)
    在選舉過程中,Zookeeper服務器有四種狀態(tài)迫像,它們分別為競選狀態(tài)(Looking)劈愚、隨從狀態(tài)(Following,同步leader狀態(tài),參與投票)闻妓、觀察狀態(tài)(Observing,同步不leader狀態(tài)菌羽,不參與投票)、領導者狀態(tài)(Leader)由缆。
  • 數(shù)據(jù)id
    是服務器中存放的最新數(shù)據(jù)版本號注祖,該值越大則說明數(shù)據(jù)越新,在選舉過程中數(shù)據(jù)越新權(quán)重越大均唉。
  • 邏輯時鐘
    通俗的講是晨,邏輯時鐘被稱為投票次數(shù),同一輪投票過程中的邏輯時鐘值是相同的舔箭,邏輯時鐘起始值為0罩缴,每投一次票,這個數(shù)據(jù)就會增加层扶。如果某臺機器宕機靴庆,那么這臺機器不會參與投票,因此邏輯時鐘會比其他的低怒医。

選舉機制類型

Zookeeper選舉機制有兩種類型炉抒,分別為全新集群選舉和非全新集群選舉,下面分別對兩種類型進行詳細講解稚叹。

全新集群選舉

全新集群選舉是新建搭建起來的焰薄,沒有數(shù)據(jù)ID和邏輯時鐘的數(shù)據(jù)影響集群的選舉。假設扒袖,目前有5臺服務器塞茅,它們的編號分別是1-5,按編號依次啟動Zoopeer服務,以下是全過程季率。

  • 步驟1:服務器1啟動野瘦,首先,會給自己投票飒泻;其次鞭光,發(fā)投票信息。由于其他機器還沒有啟動所以它無法收到投票的反饋信息泞遗,因此服務器1的狀態(tài)一直屬于Looking狀態(tài)惰许。
  • 步驟2:服務器2的啟動,首先史辙,會給自己投票汹买;其次在集群中啟動的zookeeper服務的機器發(fā)起投票對比佩伤,這時它會與服務器1交換結(jié)果,由于服務器2的編號大晦毙,所以服務器2勝出生巡,此時服務器1會將票投給服務器2,但此時服務器2的投票數(shù)并沒有大于集群半數(shù)(2<5/2),所以兩個服務器的狀態(tài)依然是Looking狀態(tài)见妒。
  • 步驟3:服務器3啟動孤荣,首先會給自己投票;其次徐鹤,與之前啟動的服務器1垃环、2交換信息 ,由于服務器3的編號最大所以服務器3勝出返敬,那么服務器1遂庄、2會將票投給服務器3,此時投票數(shù)正好大于半數(shù)(3>5/2),所以服務器3成為領導者狀態(tài)劲赠,服務器1涛目、2稱為追隨者狀態(tài)。
  • 步驟4:服務器4啟動凛澎,首先霹肝,給自己投票;其次塑煎,與之前啟動的服務器1沫换、2、3交換信息最铁,盡管服務器4的編號大讯赏,但是服務器3已經(jīng)勝出,所以服務器4只能成為追隨者狀態(tài)冷尉。
  • 步驟5:服務器5啟動漱挎,同服務器4一樣,均成為追隨者狀態(tài)雀哨。

非全新集群選舉

對于正常運行的Zookeeper集群磕谅,-一旦中途有服務器宕機,則需耍重新選舉時雾棺,選舉的過程中就需要引入服務器ID膊夹、數(shù)據(jù)ID和邏輯時鐘。這是由于Zookeeper集群已經(jīng)運行過一-段時間垢村,那么服務器中就會存在運行的數(shù)據(jù)割疾。下面來講解非全新集群選舉的過程。

  • 步驟1:首先,統(tǒng)計邏輯時鐘是否相同嘉栓,邏輯時鐘小宏榕,則說明途中可能存在宕機問題,因此數(shù)據(jù)不完整侵佃,那么該選舉結(jié)果被忽略麻昼,重新投票選舉;
  • 步驟2:步驟2:其次,統(tǒng)- -邏輯時鐘后馋辈,對比數(shù)據(jù)ID值抚芦,數(shù)據(jù)ID反應數(shù)據(jù)的新舊程度,因此數(shù)據(jù)ID大的勝出:
  • 步驟3:步驟3:如果邏輯時鐘和數(shù)據(jù)ID都相同的情況下迈螟,那么比較服務器以(編號)叉抡,值大則勝出。

簡單的講答毫,非全新集群選舉時是優(yōu)中選優(yōu)褥民,保證Leader是Zookeeper集群中數(shù)據(jù)最完整的

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市洗搂,隨后出現(xiàn)的幾起案子消返,更是在濱河造成了極大的恐慌,老刑警劉巖耘拇,帶你破解...
    沈念sama閱讀 221,820評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件撵颊,死亡現(xiàn)場離奇詭異,居然都是意外死亡惫叛,警方通過查閱死者的電腦和手機倡勇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嘉涌,“玉大人妻熊,你說我怎么就攤上這事÷逍模” “怎么了固耘?”我有些...
    開封第一講書人閱讀 168,324評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長词身。 經(jīng)常有香客問我厅目,道長,這世上最難降的妖魔是什么法严? 我笑而不...
    開封第一講書人閱讀 59,714評論 1 297
  • 正文 為了忘掉前任损敷,我火速辦了婚禮,結(jié)果婚禮上深啤,老公的妹妹穿的比我還像新娘拗馒。我一直安慰自己,他們只是感情好溯街,可當我...
    茶點故事閱讀 68,724評論 6 397
  • 文/花漫 我一把揭開白布诱桂。 她就那樣靜靜地躺著洋丐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪挥等。 梳的紋絲不亂的頭發(fā)上友绝,一...
    開封第一講書人閱讀 52,328評論 1 310
  • 那天,我揣著相機與錄音肝劲,去河邊找鬼迁客。 笑死,一個胖子當著我的面吹牛辞槐,可吹牛的內(nèi)容都是我干的掷漱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,897評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼榄檬,長吁一口氣:“原來是場噩夢啊……” “哼卜范!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起丙号,我...
    開封第一講書人閱讀 39,804評論 0 276
  • 序言:老撾萬榮一對情侶失蹤先朦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后犬缨,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體喳魏,經(jīng)...
    沈念sama閱讀 46,345評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,431評論 3 340
  • 正文 我和宋清朗相戀三年怀薛,在試婚紗的時候發(fā)現(xiàn)自己被綠了刺彩。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,561評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡枝恋,死狀恐怖创倔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情焚碌,我是刑警寧澤畦攘,帶...
    沈念sama閱讀 36,238評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站十电,受9級特大地震影響知押,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鹃骂,卻給世界環(huán)境...
    茶點故事閱讀 41,928評論 3 334
  • 文/蒙蒙 一台盯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧畏线,春花似錦静盅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽明垢。三九已至,卻和暖如春栈虚,著一層夾襖步出監(jiān)牢的瞬間袖外,已是汗流浹背史隆。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評論 1 272
  • 我被黑心中介騙來泰國打工魂务, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泌射。 一個月前我還...
    沈念sama閱讀 48,983評論 3 376
  • 正文 我出身青樓粘姜,卻偏偏與公主長得像,于是被迫代替她去往敵國和親熔酷。 傳聞我的和親對象是個殘疾皇子孤紧,可洞房花燭夜當晚...
    茶點故事閱讀 45,573評論 2 359