在項(xiàng)目中使用了Nacos作為配置中心和服務(wù)注冊中心,不禁會(huì)想起Zookeeper也是可以做同樣的事情尸昧,那么兩者有什么異同處呢揩页?終于找了一個(gè)時(shí)間整理出下面這篇文章。
主要平時(shí)用的較多是配置中心和服務(wù)注冊中心烹俗,所以也是結(jié)合這兩點(diǎn)功能做出對(duì)應(yīng)的對(duì)比爆侣,主要比對(duì)集群模式。
以下僅僅整理了個(gè)人理解后的觀點(diǎn)幢妄,如有疑問歡迎咨詢討論兔仰。
1.Zookeeper
其實(shí)明白一點(diǎn)Zookeeper的功能主要是它的樹形節(jié)點(diǎn)來實(shí)現(xiàn)的。當(dāng)有數(shù)據(jù)變化的時(shí)候或者節(jié)點(diǎn)過期的時(shí)候蕉鸳,會(huì)通過事件觸發(fā)通知對(duì)應(yīng)的客戶端數(shù)據(jù)變化了乎赴,然后客戶端再請(qǐng)求zk獲取最新數(shù)據(jù),采用push-pull來做數(shù)據(jù)更新潮尝。
ZK最重要的就是它的ZAB(消息廣播和崩潰恢復(fù))協(xié)議了榕吼。
消息廣播: 集群中zk在數(shù)據(jù)更新的時(shí)候,通過leader節(jié)點(diǎn)將將消息廣播給其他follower節(jié)點(diǎn)勉失,采用簡單的兩階段提交模式羹蚣,先request->ack->commit,當(dāng)超過一半的follower節(jié)點(diǎn)響應(yīng)可以提交就更新代碼乱凿。
崩潰恢復(fù): 當(dāng)leader掛了顽素,或者超半數(shù)follower投票得出leader不可用,那么會(huì)重新選舉告匠,這段期間zk服務(wù)是不可用的戈抄。通過最新的 xid來選舉出新的leader,選舉出來后需要將新的leader中的數(shù)據(jù)更新給超過半數(shù)的follower節(jié)點(diǎn)才能對(duì)外提供服務(wù)后专。
2.Nacos
Nacos的配置中心和注冊中心實(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ù)庫做數(shù)據(jù)存儲(chǔ)型凳,當(dāng)有數(shù)據(jù)更新的時(shí)候丈冬,直接更新數(shù)據(jù)庫的數(shù)據(jù),然后將數(shù)據(jù)更新的信息異步廣播給Nacos集群中所有服務(wù)節(jié)點(diǎn)數(shù)據(jù)變更甘畅,在由Nacos服務(wù)節(jié)點(diǎn)更新本地緩存埂蕊,然后將通知客戶端節(jié)點(diǎn)數(shù)據(jù)變化往弓。
Zookeeper:利用zk的樹型結(jié)構(gòu)做數(shù)據(jù)存儲(chǔ),當(dāng)有數(shù)據(jù)更新的時(shí)候使用過半機(jī)制保證各個(gè)節(jié)點(diǎn)的數(shù)據(jù)一致性蓄氧;然后通過zk的事件機(jī)制通知客戶端函似。
這里可以明顯發(fā)現(xiàn)差異:
- 服務(wù)器存儲(chǔ)位置不同,分別采用mysql和zk本身存儲(chǔ)
- 消息發(fā)送喉童,一個(gè)有采用過半機(jī)制保持一致性撇寞,另外一個(gè)異步廣播,通過后臺(tái)線程重試保證堂氯。
2.注冊中心
Nacos:nacos支持兩種方式的注冊中心蔑担,持久化和非持久化存儲(chǔ)服務(wù)信息。
- 非持久直接存儲(chǔ)在nacos服務(wù)節(jié)點(diǎn)的內(nèi)存中咽白,并且服務(wù)節(jié)點(diǎn)間采用去中心化的思想啤握,服務(wù)節(jié)點(diǎn)采用hash分片存儲(chǔ)注冊信息
- 持久化使用Raft協(xié)議選舉master節(jié)點(diǎn),同樣采用過半機(jī)制將數(shù)據(jù)存儲(chǔ)在leader節(jié)點(diǎn)上
Zookeeper:利用zk的樹型結(jié)構(gòu)做數(shù)據(jù)存儲(chǔ)晶框,服務(wù)注冊和消費(fèi)信息直接存儲(chǔ)在zk樹形節(jié)點(diǎn)上恨统,集群下同樣采用過半機(jī)制保證服務(wù)節(jié)點(diǎn)間一致性
這里的差異:
- nacos支持持久化和非持久化存儲(chǔ)即有點(diǎn) AP和CP 分布式一致性的概念,nacos的CP-持久化更像貼合zk的模式(過半機(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ǔ)起來應(yīng)該意義不大模燥,及時(shí)變化才是真理咖祭。
所謂仁者見仁,智者見智蔫骂。每一款產(chǎn)品都有各自的特點(diǎn)么翰,具體看怎么用就看自身的業(yè)務(wù)的場景了。