Nacos和Zookeeper對(duì)比

在項(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ù)的場景了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末辽旋,一起剝皮案震驚了整個(gè)濱河市浩嫌,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌补胚,老刑警劉巖码耐,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異溶其,居然都是意外死亡骚腥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門瓶逃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來束铭,“玉大人廓块,你說我怎么就攤上這事∑跄” “怎么了剿骨?”我有些...
    開封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長埠褪。 經(jīng)常有香客問我挤庇,道長,這世上最難降的妖魔是什么渴语? 我笑而不...
    開封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮调违,結(jié)果婚禮上泻轰,老公的妹妹穿的比我還像新娘。我一直安慰自己浮声,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開白布然痊。 她就那樣靜靜地躺著屉符,像睡著了一般矗钟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袋马,一...
    開封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音桑谍,去河邊找鬼延柠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛锣披,可吹牛的內(nèi)容都是我干的增热。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼人断,長吁一口氣:“原來是場噩夢啊……” “哼恶迈!你這毒婦竟也來了蝉绷?” 一聲冷哼從身側(cè)響起熔吗,我...
    開封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤讼载,失蹤者是張志新(化名)和其女友劉穎中跌,沒想到半個(gè)月后漩符,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體议蟆,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡戳粒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年蔚约,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片孝鹊。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖展蒂,靈堂內(nèi)的尸體忽然破棺而出又活,到底是詐尸還是另有隱情,我是刑警寧澤锰悼,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布柳骄,位于F島的核電站,受9級(jí)特大地震影響箕般,放射性物質(zhì)發(fā)生泄漏耐薯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一丝里、第九天 我趴在偏房一處隱蔽的房頂上張望曲初。 院中可真熱鬧,春花似錦杯聚、人聲如沸臼婆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽颁褂。三九已至,卻和暖如春傀广,著一層夾襖步出監(jiān)牢的瞬間颁独,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來泰國打工伪冰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留誓酒,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓贮聂,卻偏偏與公主長得像丰捷,于是被迫代替她去往敵國和親坯墨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345