在項(xiàng)目中使用了Nacos作為配置中心和服務(wù)注冊(cè)中心,不禁會(huì)想起Zookeeper也是可以做同樣的事情,那么兩者有什么異同處呢?終于找了一個(gè)時(shí)間整理出下面這篇文章。
主要平時(shí)用的較多是配置中心和服務(wù)注冊(cè)中心,所以也是結(jié)合這兩點(diǎn)功能做出對(duì)應(yīng)的對(duì)比,主要比對(duì)集群模式。
以下僅僅整理了個(gè)人理解后的觀點(diǎn),如有疑問(wèn)歡迎咨詢討論。
1.Zookeeper
其實(shí)明白一點(diǎn)Zookeeper的功能主要是它的樹(shù)形節(jié)點(diǎn)來(lái)實(shí)現(xiàn)的。當(dāng)有數(shù)據(jù)變化的時(shí)候或者節(jié)點(diǎn)過(guò)期的時(shí)候,會(huì)通過(guò)事件觸發(fā)通知對(duì)應(yīng)的客戶端數(shù)據(jù)變化了,然后客戶端再請(qǐng)求zk獲取最新數(shù)據(jù),采用push-pull來(lái)做數(shù)據(jù)更新。
ZK最重要的就是它的ZAB(消息廣播和崩潰恢復(fù))協(xié)議了。
消息廣播: 集群中zk在數(shù)據(jù)更新的時(shí)候,通過(guò)leader節(jié)點(diǎn)將將消息廣播給其他follower節(jié)點(diǎn),采用簡(jiǎn)單的兩階段提交模式,先request->ack->commit,當(dāng)超過(guò)一半的follower節(jié)點(diǎn)響應(yīng)可以提交就更新代碼。
崩潰恢復(fù): 當(dāng)leader掛了,或者超半數(shù)follower投票得出leader不可用,那么會(huì)重新選舉,這段期間zk服務(wù)是不可用的。通過(guò)最新的 xid來(lái)選舉出新的leader,選舉出來(lái)后需要將新的leader中的數(shù)據(jù)更新給超過(guò)半數(shù)的follower節(jié)點(diǎn)才能對(duì)外提供服務(wù)。
2.Nacos
Nacos的配置中心和注冊(cè)中心實(shí)現(xiàn)的是兩套代碼,和Zk不同,
1.配置中心
Nacos和Zookeeper都可以作為配置中心,做一些可以實(shí)時(shí)變化的配置數(shù)據(jù)存儲(chǔ),然后實(shí)時(shí)更新線上數(shù)據(jù)。
1.1 存儲(chǔ)和數(shù)據(jù)更新
Nacos:依賴Mysql數(shù)據(jù)庫(kù)做數(shù)據(jù)存儲(chǔ),當(dāng)有數(shù)據(jù)更新的時(shí)候,直接更新數(shù)據(jù)庫(kù)的數(shù)據(jù),然后將數(shù)據(jù)更新的信息異步廣播給Nacos集群中所有服務(wù)節(jié)點(diǎn)數(shù)據(jù)變更,在由Nacos服務(wù)節(jié)點(diǎn)更新本地緩存,然后將通知客戶端節(jié)點(diǎn)數(shù)據(jù)變化。
Zookeeper:利用zk的樹(shù)型結(jié)構(gòu)做數(shù)據(jù)存儲(chǔ),當(dāng)有數(shù)據(jù)更新的時(shí)候使用過(guò)半機(jī)制保證各個(gè)節(jié)點(diǎn)的數(shù)據(jù)一致性;然后通過(guò)zk的事件機(jī)制通知客戶端。
這里可以明顯發(fā)現(xiàn)差異:
- 服務(wù)器存儲(chǔ)位置不同,分別采用mysql和zk本身存儲(chǔ)
- 消息發(fā)送,一個(gè)有采用過(guò)半機(jī)制保持一致性,另外一個(gè)異步廣播,通過(guò)后臺(tái)線程重試保證。
2.注冊(cè)中心
Nacos:nacos支持兩種方式的注冊(cè)中心,持久化和非持久化存儲(chǔ)服務(wù)信息。
- 非持久直接存儲(chǔ)在nacos服務(wù)節(jié)點(diǎn)的內(nèi)存中,并且服務(wù)節(jié)點(diǎn)間采用去中心化的思想,服務(wù)節(jié)點(diǎn)采用hash分片存儲(chǔ)注冊(cè)信息
- 持久化使用Raft協(xié)議選舉master節(jié)點(diǎn),同樣采用過(guò)半機(jī)制將數(shù)據(jù)存儲(chǔ)在leader節(jié)點(diǎn)上
Zookeeper:利用zk的樹(shù)型結(jié)構(gòu)做數(shù)據(jù)存儲(chǔ),服務(wù)注冊(cè)和消費(fèi)信息直接存儲(chǔ)在zk樹(shù)形節(jié)點(diǎn)上,集群下同樣采用過(guò)半機(jī)制保證服務(wù)節(jié)點(diǎn)間一致性
這里的差異:
- nacos支持持久化和非持久化存儲(chǔ)即有點(diǎn) AP和CP 分布式一致性的概念,nacos的CP-持久化更像貼合zk的模式(過(guò)半機(jī)制),默認(rèn)非持久化采用內(nèi)存存儲(chǔ)速度更快,而且分片存儲(chǔ),不利點(diǎn)就是某個(gè)服務(wù)節(jié)點(diǎn)掛掉,可能出現(xiàn)部分時(shí)間調(diào)用失敗。因?yàn)榉?wù)調(diào)用本身就是實(shí)時(shí)的,持久化存儲(chǔ)起來(lái)應(yīng)該意義不大,及時(shí)變化才是真理。
所謂仁者見(jiàn)仁,智者見(jiàn)智。每一款產(chǎn)品都有各自的特點(diǎn),具體看怎么用就看自身的業(yè)務(wù)的場(chǎng)景了。