青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

loop_in_codes

低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

圖解zookeeper FastLeader選舉算法

zookeeper配置為集群模式時,在啟動或異常情況時會選舉出一個實例作為Leader。其默認選舉算法為FastLeaderElection

不知道zookeeper的可以考慮這樣一個問題:某個服務可以配置為多個實例共同構成一個集群對外提供服務。其每一個實例本地都存有冗余數據,每一個實例都可以直接對外提供讀寫服務。在這個集群中為了保證數據的一致性,需要有一個Leader來協調一些事務。那么問題來了:如何確定哪一個實例是Leader呢?

問題的難點在于:

  • 沒有一個仲裁者來選定Leader
  • 每一個實例本地可能已經存在數據,不確定哪個實例上的數據是最新的

分布式選舉算法正是用來解決這個問題的。

本文基于zookeeper 3.4.6 的源碼進行分析。FastLeaderElection算法的源碼全部位于FastLeaderElection.java文件中,其對外接口為FastLeaderElection.lookForLeader,該接口是一個同步接口,直到選舉結束才會返回。同樣由于網上已有類似文章,所以我就從圖示的角度來闡述。閱讀一些其他文章有利于獲得初步印象:

主要流程

閱讀代碼和以上推薦文章可以把整個流程梳理清楚。實現上,包括了一個消息處理主循環,也是選舉的主要邏輯,以及一個消息發送隊列處理線程和消息解碼線程。主要流程可概括為下圖:

fle-flow.png

推薦對照著推薦的文章及代碼理解,不贅述。

我們從感性上來理解這個算法。

每一個節點,相當于一個選民,他們都有自己的推薦人,最開始他們都推薦自己。誰更適合成為Leader有一個簡單的規則,例如sid夠大(配置)、持有的數據夠新(zxid夠大)。每個選民都告訴其他選民自己目前的推薦人是誰,類似于出去搞宣傳拉攏其他選民。每一個選民發現有比自己更適合的人時就轉而推薦這個更適合的人。最后,大部分人意見一致時,就可以結束選舉。

就這么簡單。總體上有一種不斷演化逼近結果的感覺。

當然,會有些特殊情況的處理。例如總共3個選民,1和2已經確定3是Leader,但3還不知情,此時就走入LEADING/FOLLOWING的分支,選民3只是接收結果。

代碼中不是所有邏輯都在這個大流程中完成的。在接收消息線程中,還可能單獨地回應某個節點(WorkerReceiver.run):

recv.png

從這里可以看出,當某個節點已經確定選舉結果不再處于LOOKING狀態時,其收到LOOKING消息時都會直接回應選舉的最終結果。結合上面那個比方,相當于某次選舉結束了,這個時候來了選民4又發起一次新的選舉,那么其他選民就直接告訴它當前的Leader情況。相當于,在這個集群主從已經就緒的情況下,又開啟了一個實例,這個實例就會直接使用當前的選舉結果。

狀態轉換

每個節點上有一些關鍵的數據結構:

  • 當前推薦人,初始推薦自己,每次收到其他更好的推薦人時就更新
  • 其他人的投票集合,用于確定何時選舉結束

每次推薦人更新時就會進行廣播,正是這個不斷地廣播驅動整個算法趨向于結果。假設有3個節點A/B/C,其都還沒有數據,按照sid關系為C>B>A,那么按照規則,C更可能成為Leader,其各個節點的狀態轉換為:

state.png

圖中,v(A)表示當前推薦人為A;r[]表示收到的投票集合。

可以看看當其他節點已經確定投票結果時,即不再是LOOKING時的狀態:

state-ret.png

代碼中有一個特殊的投票集合outofelection,我理解為選舉已結束的那些投票,這些投票僅用于表征選舉結果。

當一個新啟動的節點加入集群時,它對集群內其他節點發出投票請求,而其他節點已不處于LOOKING狀態,此時其他節點回應選舉結果,該節點收集這些結果到outofelection中,最終在收到合法LEADER消息且這些選票也構成選舉結束條件時,該節點就結束自己的選舉行為。注意到代碼中會logicalclock = n.electionEpoch;更新選舉輪數

posted on 2014-10-19 15:58 Kevin Lynx 閱讀(4517) 評論(0)  編輯 收藏 引用 所屬分類: network

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品毛片a∨一区二区三区|国| 国产精品三上| 欧美在现视频| 久久综合国产精品| 夜色激情一区二区| 亚洲精品乱码视频| 免费观看成人www动漫视频| 亚洲精品国久久99热| 亚洲激情在线观看视频免费| 亚洲免费在线观看视频| 欧美aaa级| 在线日韩一区二区| 亚洲精品一区二区三区樱花| 久久不射2019中文字幕| 欧美综合国产精品久久丁香| 久久先锋资源| 激情一区二区| 欧美中文字幕视频| 午夜精品999| 在线欧美小视频| 亚洲剧情一区二区| 国产精品女人久久久久久| 久久久噜噜噜久久人人看| 欧美精品免费播放| 亚洲免费大片| 欧美综合国产| 亚洲国产精品悠悠久久琪琪| 中国成人黄色视屏| 欧美理论在线| 久久久久久999| 欧美激情第一页xxx| 榴莲视频成人在线观看| 国产精品成人aaaaa网站| 亚洲激情婷婷| 亚洲人成小说网站色在线| 国产精品v欧美精品v日韩精品 | 亚洲大胆在线| 欧美日韩亚洲综合在线| 欧美日韩视频| 久久久99久久精品女同性| 欧美日韩在线播放| 欧美一区二区三区婷婷月色| 久久综合伊人77777蜜臀| 午夜久久久久久| 欧美日韩你懂的| 欧美大片网址| 伊人激情综合| 老司机精品视频网站| 久久亚洲一区| 在线观看成人网| 久久日韩精品| 免费成人性网站| 久久se精品一区精品二区| 亚洲国产成人高清精品| 欧美日韩成人一区| 亚洲色在线视频| 久久久久国色av免费观看性色| 国产精品一区二区视频 | 久久夜色精品亚洲噜噜国产mv| 久久午夜色播影院免费高清| 国产精品一二三| 欧美成人精品激情在线观看| 亚洲一二三区视频在线观看| 亚洲福利视频二区| 久久久av水蜜桃| 一本色道久久精品| 欧美日韩国产色站一区二区三区 | 欧美怡红院视频一区二区三区| 老牛嫩草一区二区三区日本| 亚洲破处大片| 欧美日韩福利在线观看| 韩国三级电影一区二区| 午夜精品电影| 亚洲人成亚洲人成在线观看| 亚洲人精品午夜| 国产精品日韩欧美一区| 久久在线免费观看视频| 亚洲视频在线观看视频| 在线亚洲免费视频| 日韩亚洲精品视频| 亚洲精品一区在线观看| 亚洲国产乱码最新视频| 亚洲乱码国产乱码精品精天堂| 欧美~级网站不卡| 99riav久久精品riav| 国产免费亚洲高清| 国产免费一区二区三区香蕉精| 国产精品九九| 国产精品久久久久久久免费软件| 久久国产黑丝| 欧美日韩国产黄| 欧美网站在线观看| 国产丝袜美腿一区二区三区| 亚洲国产精品精华液2区45| 国产精品99久久久久久久女警| 久久精品国产亚洲高清剧情介绍| 在线视频中文亚洲| 亚洲午夜av在线| 欧美日韩一区二区欧美激情| 欧美日韩国产成人在线免费| 卡通动漫国产精品| 国产色综合天天综合网| 国产日本精品| 国产精品99久久久久久宅男| 欧美福利电影在线观看| 欧美综合77777色婷婷| 美日韩在线观看| 国模私拍视频一区| 在线日韩成人| 欧美一级大片在线观看| 国产精品超碰97尤物18| 亚洲高清在线视频| 欧美一区国产在线| 亚洲午夜91| 久久综合给合久久狠狠色| 国产精品嫩草影院一区二区| 亚洲精品一区二区三区在线观看| 午夜激情综合网| 午夜在线精品偷拍| 欧美日韩国产美| 99国产精品99久久久久久| 久久久亚洲综合| 欧美激情欧美狂野欧美精品| 亚洲精选久久| 久久精品国产一区二区三区免费看| 国产精品免费网站| 久久人人爽国产| 欧美精品福利视频| 久久超碰97中文字幕| 日韩视频免费观看高清在线视频| 农村妇女精品| 欧美伊人久久| 欧美福利视频一区| 久久成人精品无人区| 亚洲欧美在线免费观看| 国产日韩精品视频一区| 欧美一级午夜免费电影| 欧美不卡视频一区发布| 亚洲欧美日韩精品久久久| 午夜国产不卡在线观看视频| 国产精品九九| 免费欧美电影| 国内精品嫩模av私拍在线观看| 亚洲国产视频一区| 国产精品国内视频| 久久免费少妇高潮久久精品99| 免费不卡中文字幕视频| 亚洲欧美日韩中文视频| 久久久福利视频| 亚洲在线一区二区| 久久青草久久| 久久av在线| 国内偷自视频区视频综合| 99热免费精品| 久久久精品一区二区三区| 久久久天天操| 国产精品va| 老司机一区二区三区| 久久av一区二区三区| 一区福利视频| 欧美二区在线观看| 亚洲高清一区二| 亚洲国产精品一区在线观看不卡 | 欧美不卡在线视频| 亚洲视频综合| 国产精品www994| 欧美亚洲网站| 美女图片一区二区| 国产综合色在线视频区| 欧美日韩另类国产亚洲欧美一级| 久久久久久尹人网香蕉| 在线观看福利一区| 欧美一区二区大片| 亚洲视频在线观看网站| 亚洲国产视频一区二区| 久久成人免费电影| 99riav1国产精品视频| 国产一区二区在线观看免费播放| 欧美日本不卡视频| 欧美午夜在线视频| 欧美三级在线| 亚洲精品久久久久久下一站 | 国产精品毛片大码女人| 亚洲一区在线看| 麻豆9191精品国产| 亚洲特级片在线| 亚洲尤物精选| 亚洲承认在线| 黄色日韩在线| 国产亚洲一区精品| 欧美精品久久久久久| 欧美视频中文在线看| 久久艳片www.17c.com| 久久在线视频| 免费看成人av| 你懂的国产精品| 免费观看欧美在线视频的网站| 亚洲欧美一区二区在线观看| 一区二区三区视频在线看| 亚洲国产美女精品久久久久∴|