首頁技術文章正文

Python提高筆記整理(二)

更新時間:2018-07-30 來源:黑馬程序員 瀏覽量:

2.Zookeeper 集群 
2.1 Zookeeper 集群簡介 
2.1.1 為什么搭建 Zookeeper 集群 
大部分分布式應用需要一個主控、協調器或者控制器來管理物理分布的子進程。目前,
大多數都要開發(fā)私有的協調程序,缺乏一個通用機制,協調程序的反復編寫浪費,且難以形 成通用、伸縮性好的協調器,zookeeper 提供通用的分布式鎖服務,用以協調分布式應用。 所以說 zookeeper 是分布式應用的協作服務。 
zookeeper 作為注冊中心,服務器和客戶端都要訪問,如果有大量的并發(fā),肯定會有等 待。所以可以通過 zookeeper 集群解決。 
下面是 zookeeper 集群部署結構圖: 
1532913170508_1.jpg2.1.2 了解 Leader 選舉 
Zookeeper 的啟動過程中 leader 選舉是非常重要而且最復雜的一個環(huán)節(jié)。那么什么是 leader選舉呢?zookeeper為什么需要leader選舉呢?zookeeper的leader選舉的過程又是什 么樣子的? 
首先我們來看看什么是 leader 選舉。其實這個很好理解,leader 選舉就像總統選舉一樣, 每人一票,獲得多數票的人就當選為總統了。在 zookeeper 集群中也是一樣,每個節(jié)點都會 投票,如果某個節(jié)點獲得超過半數以上的節(jié)點的投票,則該節(jié)點就是 leader 節(jié)點了。 
以一個簡單的例子來說明整個選舉的過程.   假設有五臺服務器組成的 zookeeper 集群,它們的 id 從 1-5,同時它們都是最新啟動的,也 就是沒有歷史數據,在存放數據量這一點上,都是一樣的.假設這些服務器依序啟動,來看看會 發(fā)生什么 。 
   1) 服務器 1 啟動,此時只有它一臺服務器啟動了,它發(fā)出去的報沒有任何響應,所以它的 選舉狀態(tài)一直是 LOOKING 狀態(tài)   
   2) 服務器 2 啟動,它與最開始啟動的服務器 1 進行通信,互相交換自己的選舉結果,由于 兩者都沒有歷史數據,所以id 值較大的服務器2勝出,但是由于沒有達到超過半數以上的服務 器都同意選舉它(這個例子中的半數以上是 3),所以服務器 1,2 還是繼續(xù)保持 LOOKING 狀態(tài).   
   3) 服務器 3 啟動,根據前面的理論分析,服務器 3 成為服務器 1,2,3 中的老大,而與上面不 同的是,此時有三臺服務器選舉了它,所以它成為了這次選舉的 leader.   
   4) 服務器 4 啟動,根據前面的分析,理論上服務器 4 應該是服務器 1,2,3,4 中最大的,但是 由于前面已經有半數以上的服務器選舉了服務器 3,所以它只能接收當小弟的命了.   



作者:黑馬程序員人工智能+python培訓學院
首發(fā):http://python.itheima.com/
分享到:
在線咨詢 我要報名
和我們在線交談!