精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分布式系統的“腦裂”到底是個什么玩意?

網絡 通信技術 分布式
目前大多數項目都在往分布式上發展,一旦系統采用分布式系統,便會引入更多復雜場景和解決方案。比如,當你在系統中使用了Elasticsearch、ZooKeeper集群時,你是否了解過集群的“腦裂”現象?又是否知道它們是如何解決腦裂問題的?

[[413929]]

本文轉載自微信公眾號「程序新視界」,作者丑胖俠二師兄 。轉載本文請聯系程序新視界公眾號。

目前大多數項目都在往分布式上發展,一旦系統采用分布式系統,便會引入更多復雜場景和解決方案。比如,當你在系統中使用了Elasticsearch、ZooKeeper集群時,你是否了解過集群的“腦裂”現象?又是否知道它們是如何解決腦裂問題的?

如果這些都還未了解,那么你對分布式的了解過于表象了,推薦你讀一讀這篇文章。

下面就以zookeeper為例,帶大家了解一下分布式系統中的腦裂現象及如何解決。

什么是腦裂?

在Elasticsearch、ZooKeeper這些集群環境中,有一個共同的特點,就是它們有一個“大腦”。比如,Elasticsearch集群中有Master節點,ZooKeeper集群中有Leader節點。

集群中的Master或Leader節點往往是通過選舉產生的。在網絡正常的情況下,可以順利的選舉出Leader(后續以Zookeeper命名為例)。但當兩個機房之間的網絡通信出現故障時,選舉機制就有可能在不同的網絡分區中選出兩個Leader。當網絡恢復時,這兩個Leader該如何處理數據同步?又該聽誰的?這也就出現了“腦裂”現象。

通俗的講,腦裂(split-brain)就是“大腦分裂”,本來一個“大腦”被拆分成兩個或多個。試想,如果一個人有多個大腦,且相互獨立,就會導致人體“手舞足蹈”,“不聽使喚”。

了解了腦裂的基本概念,下面就以zookeeper集群的場景為例,來分析一下腦裂的發生。

zookeeper集群中的腦裂

我們在使用zookeeper時,很少遇到腦裂現象,是因為zookeeper已經采取了相應的措施來減少或避免腦裂的發生,這個后面會講到Zookeeper的具體解決方案。現在呢,先假設zookeeper沒有采取這些防止腦裂的措施。在這種情況下,看看腦裂問題是如何發生的。

現有6臺zkServer服務組成了一個集群,部署在2個機房:

腦裂

正常情況下,該集群只有會有個Leader,當Leader宕掉時,其他5個服務會重新選舉出一個新的Leader。

如果機房1和機房2之間的網絡出現故障,暫時不考慮Zookeeper的過半機制,那么就會出現下圖的情況:

腦裂

也就是說機房2的三臺服務檢測到沒有Leader了,于是開始重新選舉,選舉出一個新Leader來。原本一個集群,被分成了兩個集群,同時出現了兩個“大腦”,這就是所謂的“腦裂”現象。

由于原本的一個集群變成了兩個,都對外提供服務。一段時間之后,兩個集群之間的數據可能會變得不一致了。當網絡恢復時,就面臨著誰當Leader,數據怎么合并,數據沖突怎么解決等問題。

當然,上面的過程只是我們假設Zookeeper不做任何預防腦裂措施時會出現的問題。那么,針對腦裂問題,Zookeeper是如何進行處理的呢?

Zookeeper的過半原則

防止腦裂的措施有多種,Zookeeper默認采用的是“過半原則”。所謂的過半原則就是:在Leader選舉的過程中,如果某臺zkServer獲得了超過半數的選票,則此zkServer就可以成為Leader了。

底層源碼實現如下:

  1. public class QuorumMaj implements QuorumVerifier { 
  2.   
  3.     int half; 
  4.      
  5.     // QuorumMaj構造方法。 
  6.     // 其中,參數n表示集群中zkServer的個數,不包括觀察者節點 
  7.     public QuorumMaj(int n){ 
  8.         this.half = n/2; 
  9.     } 
  10.  
  11.     // 驗證是否符合過半機制 
  12.     public boolean containsQuorum(Set<Long> set){ 
  13.         // half是在構造方法里賦值的 
  14.         // set.size()表示某臺zkServer獲得的票數 
  15.         return (set.size() > half); 
  16.     } 

上述代碼在構建QuorumMaj對象時,傳入了集群中有效節點的個數;containsQuorum方法提供了判斷某臺zkServer獲得的票數是否超過半數,其中set.size表示某臺zkServer獲得的票數。

上述代碼核心點兩個:第一,如何計算半數;第二,投票屬于半數的比較。

以上圖6臺服務器為例來進行說明:half = 6 / 2 = 3,也就是說選舉的時候,要成為Leader至少要有4臺機器投票才能夠選舉成功。那么,針對上面2個機房斷網的情況,由于機房1和機房2都只有3臺服務器,根本無法選舉出Leader。這種情況下整個集群將沒有Leader。

腦裂

在沒有Leader的情況下,會導致Zookeeper無法對外提供服務,所以在設計的時候,我們在集群搭建的時候,要避免這種情況的出現。

如果兩個機房的部署請求部署3:3這種狀況,而是3:2,也就是機房1中三臺服務器,機房2中兩臺服務器:

在上述情況下,先計算half = 5 / 2 = 2,也就是需要大于2臺機器才能選舉出Leader。那么此時,對于機房1可以正常選舉出Leader。對于機房2來說,由于只有2臺服務器,則無法選出Leader。此時整個集群只有一個Leader。

對于上圖,顛倒過來也一樣,比如機房1只有2臺服務器,機房2有三臺服務器,當網絡斷開時,選舉情況如下:

Zookeeper集群通過過半機制,達到了要么沒有Leader,要沒只有1個Leader,這樣就避免了腦裂問題。

對于過半機制除了能夠防止腦裂,還可以實現快速的選舉。因為過半機制不需要等待所有zkServer都投了同一個zkServer就可以選舉出一個Leader,所以也叫快速領導者選舉算法。

新舊Leader爭奪

通過過半原則可以防止機房分區時導致腦裂現象,但還有一種情況就是Leader假死。

假設某個Leader假死,其余的followers選舉出了一個新的Leader。這時,舊的Leader復活并且仍然認為自己是Leader,向其他followers發出寫請求也是會被拒絕的。

因為ZooKeeper維護了一個叫epoch的變量,每當新Leader產生時,會生成一個epoch標號(標識當前屬于那個Leader的統治時期),epoch是遞增的,followers如果確認了新的Leader存在,知道其epoch,就會拒絕epoch小于現任leader epoch的所有請求。

那有沒有follower不知道新的Leader存在呢,有可能,但肯定不是大多數,否則新Leader無法產生。ZooKeeper的寫也遵循quorum機制,因此,得不到大多數支持的寫是無效的,舊leader即使各種認為自己是Leader,依然沒有什么作用。

ZooKeeper集群節點為什么要部署成奇數

上面講了過半原則,由于Zookeeper默認采用的就是這種策略,那就帶來另外一個問題。集群的數量設置為多少合適呢?而我們所看到的Zookeeper節點數一般都是奇數,這是為什么呢?

首先,只要集群中有過半的機器是正常工作的,那么整個集群就可對外服務。那么我們列舉一些情況,來看看在這些情況下集群的容錯性。

如果有2個節點,那么只要掛掉1個節點,集群就不可用了。此時,集群對的容忍度為0;

如果有3個節點,那么掛掉1個節點,還有剩下2個正常節點,超過半數,可以重新選舉,正常服務。此時,集群的容忍度為1;

如果有4個節點,那么掛掉1個節點,剩下3個,超過半數,可以重新選舉。但如果再掛掉1個,只剩下2個,就無法正常選舉和服務了。此時,集群的容忍度為1;

依次類推,5個節點,容忍度為2;6個節點容忍度同樣為2;

既然3個節點和4個節點、5個節點和6個節點,也就是2n和2n-1的容忍度是一樣的,都是n-1。那么,為了節省資源,為了更加高效(更多節點參與選舉和通信),為什么不少一個節點呢?這就是為什么集群要部署成奇數的原因。

解決腦裂的常見方法

上面提到了Zookeeper使用的過半原則,這里再把解決腦裂問題的場景方式總結一下。

方法一,Quorums(法定人數)方式

比如3個節點的集群,Quorums = 2,也就是說集群可以容忍1個節點失效,這時候還能選舉出1個lead,集群還可用。比如4個節點的集群,它的Quorums = 3,Quorums要超過3,相當于集群的容忍度還是1,如果2個節點失效,那么整個集群還是無效的。這是ZooKeeper防止“腦裂”默認采用的方法。

方法二,添加心跳線

集群中采用多種通信方式,防止一種通信方式失效導致集群中的節點無法通信。

比如,添加心跳線。原來只有一條心跳線路,此時若斷開,則接收不到心跳報告,判斷對方已經死亡。若有2條心跳線路,一條斷開,另一條仍然能夠接收心跳報告,能保證集群服務正常運行。心跳線路之間也可以 HA(高可用),這兩條心跳線路之間也可以互相檢測,若一條斷開,則另一條馬上起作用。正常情況下,則不起作用,節約資源。

方法三,啟動磁盤鎖定方式。

使用磁盤鎖的形式,保證集群中只能有一個Leader獲取磁盤鎖,對外提供服務,避免數據錯亂發生。但是,也會存在一個問題,若該Leader節點宕機,則不能主動釋放鎖,那么其他的Follower就永遠獲取不了共享資源。于是有人在HA中設計了"智能"鎖。正在服務的一方只有在發現心跳線全部斷開(察覺不到對端)時才啟用磁盤鎖。平時就不上鎖了

方法四,仲裁機制方式。

腦裂導致的后果是從節點不知道該連接哪一臺Leader,此時有一個仲裁方就可以解決此問題。比如提供一個參考的IP地址,心跳機制斷開時,節點各自ping一下參考IP,如果ping不通,那么表示該節點網絡已經出現問題,則該節點需要自行退出爭搶資源,釋放占有的共享資源,將服務的提供功能讓給功能更全面的節點。

以上方式可以同時使用,可以減少集群中腦裂情況的發生,但不能完全保證,比如仲裁機制中2臺機器同時宕機,那么此時集群中沒有Leader 可以使用。此時就需要人工干預了。

小結

 

我們經常在說,我們的系統使用了分布式,但我們真的了解分布式中場景的一些場景和解決方案嗎?通過本文對腦裂場景的分析及解決方案介紹,你學到了嗎?來一起學習吧。

 

責任編輯:武曉燕 來源: 程序新視界
相關推薦

2012-02-13 15:50:59

2021-03-22 07:45:05

Sentinel微服務開源的項目

2010-06-28 15:58:45

EclipseJavaIDE

2010-06-29 13:39:26

Eclipse什么玩意兒

2010-07-02 10:10:09

Eclipse

2010-07-05 15:56:01

EclipseRCPECF

2018-04-26 11:05:55

分布式系統集中式系統數據處理

2011-11-21 10:25:29

iCloud

2021-12-13 19:57:05

JNDIJava開發

2022-08-22 09:25:47

分布式系統單塊系統

2020-10-29 07:03:56

Docker容器存儲

2022-06-20 05:25:54

裂腦Oracle RAC數據庫

2021-01-29 12:24:22

電腦電子計算機

2020-10-25 20:05:29

Pythonyield開發

2022-02-16 20:04:08

容器KubernetesShim

2018-01-30 11:17:56

集群分布式SOA?

2023-05-12 08:23:03

分布式系統網絡

2024-07-03 12:04:42

C++this?

2025-10-29 07:33:13

2020-02-12 15:02:39

KVM架構圖分布式
點贊
收藏

51CTO技術棧公眾號

亚洲色图视频免费播放| 精品少妇3p| 中文在线资源观看网站视频免费不卡| 国产精品一区二区3区| 日本少妇aaa| 中文久久电影小说| 欧美日韩中国免费专区在线看| 日本欧美色综合网站免费| 国产精品久久久国产盗摄| 亚洲美女少妇无套啪啪呻吟| 中文字幕精品www乱入免费视频| 精品国产aⅴ一区二区三区东京热| 永久免费毛片在线播放| 中文字幕亚洲在| 久久精品二区| 国产99视频在线| 久久久久看片| 97欧美精品一区二区三区| 久久久久久国产免费a片| 911精品国产| 欧美日韩国产天堂| 国产成人精品视频免费看| 久久99精品久久久久久野外| aaa欧美色吧激情视频| 国产在线拍揄自揄视频不卡99 | 亚洲图片在线播放| 亚洲精品专区| 欧美精品在线第一页| 国产毛片欧美毛片久久久| 高潮久久久久久久久久久久久久 | 日韩欧美一区二区三区免费看| 亚洲第一精品福利| 国产精品久久久久野外| 国产福利91精品一区二区| 色综合天天性综合| 国产视频一视频二| 电影k8一区二区三区久久| 国产精品第四页| 亚洲激情图片| 国产毛片av在线| 91在线精品一区二区| av激情久久| 超碰在线播放97| 国产一区二区不卡| 91中文精品字幕在线视频| 一区二区视频网| 免费成人美女在线观看.| 日韩美女在线观看一区| 美女又爽又黄免费视频| 国产毛片一区| 欧洲日韩成人av| 国产午夜性春猛交ⅹxxx| 国产一区二区三区成人欧美日韩在线观看| 欧美黄色性视频| 国产一级一片免费播放| 黑丝一区二区| 97国产在线观看| 久久露脸国语精品国产91| 亚洲激情网站| 91精品国产高清自在线| 欧美一级特黄视频| 久久久久国产精品一区二区| 国产成人a亚洲精品| 蜜臀尤物一区二区三区直播| 日本欧美加勒比视频| 国产精品成人一区二区三区吃奶| 嫩草影院一区二区三区| 免播放器亚洲一区| 成人精品一区二区三区| 精品国产av一区二区三区| 国产传媒一区在线| 国产女人水真多18毛片18精品| 亚洲区小说区图片区| 久久久另类综合| 亚洲欧美电影在线观看| av电影高清在线观看| 亚洲国产精品精华液网站| jizzjizz国产精品喷水| 日韩一区二区三区免费视频| 正在播放亚洲一区| 日本不卡视频一区| 亚洲制服欧美另类| 色诱女教师一区二区三区| 日韩激情小视频| 国语自产精品视频在线看8查询8| 97成人超碰免| 一级成人免费视频| 成人晚上爱看视频| 三级三级久久三级久久18| 免费观看成人高潮| 午夜天堂影视香蕉久久| 欧美成人黄色网址| 91精品啪在线观看国产手机 | 亚洲色图14p| 日本久久一二三四| 欧美黑人视频一区| 伊人久久一区二区| 成人福利电影精品一区二区在线观看 | 国产原创中文在线观看 | 黄av在线免费观看| 图片区小说区国产精品视频| 亚洲国产精品三区| 国产精品chinese在线观看| 在线电影中文日韩| 91精品国产乱码久久久张津瑜 | 国产精品综合久久久| www.久久久久久| 国产人成一区二区三区影院| 久久久国内精品| av网页在线| 国产亚洲成人一区| 国产免费成人av| 亚洲精品成av人片天堂无码| 6080成人| 一区三区二区视频| 日韩免费黄色片| 国产一区高清在线| 日本一区二区三区四区在线观看| 性国产高清在线观看| 91福利社在线观看| 欧美熟妇精品一区二区蜜桃视频| 视频在线不卡免费观看| 日本久久亚洲电影| 日本高清视频免费看| 亚洲欧洲国产日韩| 8x8x最新地址| 制服丝袜日韩| 91av在线精品| 四虎免费在线观看| 亚洲一区二区三区四区五区黄| 亚洲国产高清av| 国模吧精品视频| 国产91成人在在线播放| 亚洲欧美激情在线观看| 亚洲黄色小视频| 亚洲欧美日韩一二三区| 国产精品国产三级国产在线观看 | 欧洲av一区二区| 日韩精品极品在线观看| 免费麻豆国产一区二区三区四区| 国内国产精品久久| 自拍偷拍亚洲色图欧美| 97精品国产99久久久久久免费| 亚洲美女福利视频网站| 男人日女人网站| 久久先锋影音av| 日本三级免费观看| 国产成人影院| 国产精品久久久久久久美男| 超碰国产在线观看| 欧美日韩国产精品自在自线| 中文字幕第69页| 久久99精品一区二区三区三区| 亚洲午夜精品一区二区| 久久av影院| 久久天天躁狠狠躁夜夜躁2014| 国产欧美日韩综合精品一区二区三区| 亚洲欧洲精品天堂一级 | 免费看的黄色大片| 免费看av成人| 国产欧美中文字幕| 在线观看小视频| 亚洲电影免费观看高清| 国产无人区码熟妇毛片多| 91麻豆免费观看| 日韩一级免费在线观看| 日韩成人影院| av电影成人| 中文字幕资源网在线观看免费| 亚洲免费伊人电影在线观看av| 蜜臀尤物一区二区三区直播| 国产精品毛片a∨一区二区三区| 日韩av一卡二卡三卡| 欧美私人啪啪vps| 麻豆一区区三区四区产品精品蜜桃| 精品3atv在线视频| 久久影视电视剧免费网站清宫辞电视| 亚洲精品国产精品乱码不卡| 欧美午夜激情在线| 久久精品日韩无码| 成人动漫一区二区三区| 中文字幕第36页| 欧美国产另类| 欧美日韩精品一区| 欧美黄色一级| 欧美自拍大量在线观看| 日本免费在线观看| 亚洲国产精品资源| 在线观看毛片网站| 亚洲国产sm捆绑调教视频| 无码人妻aⅴ一区二区三区69岛| 理论电影国产精品| www..com日韩| 欧美第十八页| 久久精品综合一区| 玖玖玖视频精品| 国产suv精品一区二区| 最爽无遮挡行房视频在线| 日韩理论片久久| 国产女人高潮毛片| 欧美影院午夜播放| 国产在线拍揄自揄拍| 日本一二三不卡| 亚洲国产精品自拍视频| 国产乱人伦偷精品视频不卡| 99精品免费在线观看| 韩日成人av| 一区不卡视频| 亚洲成人一品| 国产精品久久久久免费| 全球中文成人在线| 欧洲精品毛片网站| 毛片网站在线看| zzijzzij亚洲日本成熟少妇| 蜜桃视频在线免费| 亚洲成在人线av| 精品人妻一区二区三区蜜桃| 欧美日韩中文精品| 中文字幕亚洲乱码熟女1区2区| 一区二区三区四区不卡视频| 99久久精品久久亚洲精品| 久久香蕉国产线看观看99| 97中文字幕在线观看| 九九**精品视频免费播放| 欧美午夜性生活| 国产偷自视频区视频一区二区| 97超碰在线人人| 韩日视频一区| 丁香婷婷综合激情| 欧美视频福利| 香港三级日本三级a视频| 欧美成人中文| 国产一区 在线播放| 欧美视频导航| 男人添女荫道口喷水视频| 欧美91福利在线观看| 欧美日韩一区二区三区电影| 秋霞国产午夜精品免费视频| 国产精品女人网站| 一区二区电影免费观看| 国外视频精品毛片| 麻豆福利在线观看| 欧美风情在线观看| 欧美理论电影| 欧美精品久久久久久久久| 污污片在线免费视频| 久久国产天堂福利天堂| 成年视频在线观看| 久久不射电影网| 日韩av毛片| 欧美精品videosex牲欧美| 欧美v亚洲v| 97精品一区二区视频在线观看| 爱看av在线入口| 97香蕉久久超级碰碰高清版| 蜜桃视频m3u8在线观看| 欧美亚洲国产视频小说| 少妇一区视频| 91精品在线播放| 亚洲高清在线一区| 国产亚洲欧美一区二区三区| 色吊丝一区二区| 日韩欧美亚洲v片| 99国产精品一区二区| 狠狠精品干练久久久无码中文字幕 | 欧美精品高清视频| 国产肥老妇视频| 日韩电影网在线| 成在在线免费视频| 久久国产精品影视| 欧美a级在线观看| 国产精品一区二区电影| 亚洲网址在线观看| 久久婷婷国产综合尤物精品| 日韩免费一区| 国产免费裸体视频| 久久在线精品| 伦伦影院午夜理论片| jlzzjlzz国产精品久久| 特级西西www444人体聚色| 亚洲欧美成人一区二区三区| 国偷自拍第113页| 欧美日韩精品三区| 成人午夜视频一区二区播放| 亚洲欧美制服中文字幕| av文字幕在线观看| 日韩av免费在线播放| 国产日韩一区二区三免费高清| 精品国产综合区久久久久久| 欧美理论在线播放| a级免费在线观看| 日韩av二区在线播放| 色悠悠在线视频| 中文av一区特黄| 西西44rtwww国产精品| 3751色影院一区二区三区| 香蕉视频黄在线观看| xxx成人少妇69| 免费成人直播| 成人看片在线| 99久久婷婷国产综合精品电影√| 欧美成人高潮一二区在线看| 韩国av一区二区三区在线观看| 中文字幕日韩三级片| 亚洲综合色视频| 一区二区 亚洲| 国产视频欧美视频| 日韩电影免费观看| 成人a在线视频| 国产精品无码久久av| 欧美区一区二| 狠狠97人人婷婷五月| 国产黄人亚洲片| 一级免费黄色录像| 91成人免费网站| 五月天婷婷激情网| 欧美韩国理论所午夜片917电影| 久久亚洲资源中文字| 欧美一区观看| 免费精品视频| 国产精品久久久免费观看| 一区二区三区高清不卡| 国产又黄又粗又硬| 中文字幕久精品免费视频| 天天免费亚洲黑人免费| 精品毛片久久久久久| 亚洲国产裸拍裸体视频在线观看乱了中文 | 日韩av中文字幕在线| 欧洲中文在线| 亚洲va男人天堂| 天堂美国久久| 中文字幕中文在线| 亚洲欧洲美洲综合色网| 91亚洲国产成人精品一区| 在线看国产精品| 欧美爱爱视频| 亚洲一卡二卡三卡| 麻豆免费精品视频| 中文字幕91视频| 欧美日韩夫妻久久| 国产在线观看a视频| 91色精品视频在线| 亚洲精品一区二区在线看| 亚洲欧美日本一区二区三区| 自拍偷拍亚洲综合| www.97av| 久久久久久中文字幕| 国偷自产av一区二区三区| 久久国产精品网| 92精品国产成人观看免费| 精品国产xxx| 中文字幕在线视频日韩| 日韩久久99| 国风产精品一区二区| 成人丝袜视频网| 国产成人免费看| 色av中文字幕一区| 美女国产精品久久久| 日韩伦理在线免费观看| 久久综合色一综合色88| 久久久999久久久| 久久手机免费视频| 国产日韩三级| 欧美黄色一级片视频| 国产精品水嫩水嫩| 国产jzjzjz丝袜老师水多| 久久男人av资源网站| 欧美**字幕| jizz18女人| 亚洲国产婷婷综合在线精品| 日韩国产福利| 国产美女久久精品| 亚洲视频一区| 亚洲黄色免费视频| 欧美一区午夜精品| 精精国产xxxx视频在线播放| 天堂资源在线亚洲视频| 国产激情视频一区二区三区欧美| 成人午夜视频精品一区| 尤物tv国产一区| 中文字幕av一区二区三区四区| 看av免费毛片手机播放| 亚洲人一二三区| 色视频免费在线观看| 成人国产精品av| 国产一区白浆| 欧美国产日韩在线观看成人| 精品亚洲一区二区三区在线观看| 成人一区视频| 一二三四视频社区在线| 国产精品国产馆在线真实露脸 | 国产亚洲一区二区三区| 国产丝袜视频在线观看| 5566日本婷婷色中文字幕97| 99精品电影| 日本黄色特级片| 欧美成人一级视频| 久久麻豆视频| 116极品美女午夜一级| 一区二区三区精品视频在线|