如何基于Yarn開(kāi)發(fā)你的分布式程序

前一段時(shí)間自己開(kāi)發(fā)了一套基于Yarn的容器調(diào)度系統(tǒng)刀崖,這篇文章就是分享其中的一些經(jīng)驗(yàn)抄腔。

前言

這篇文章不會(huì)具體教你如何使用Yarn的API,但是會(huì)教你我實(shí)踐過(guò)后的一些經(jīng)驗(yàn)蜀撑。接下來(lái)的內(nèi)容會(huì)探討以下兩個(gè)主題:

  1. 基于Yarn開(kāi)發(fā)分布式程序需要做的一些準(zhǔn)備工作
  2. 基于Yarn開(kāi)發(fā)容器調(diào)度系統(tǒng)的一些基本思路

基于Yarn開(kāi)發(fā)分布式程序需要做的一些準(zhǔn)備工作

肯定不能擼起袖子就開(kāi)始干村怪。你思考代碼組織,那么你會(huì)是一個(gè)好的工程師冀膝。如果你開(kāi)始思考系統(tǒng)分層結(jié)構(gòu)唁奢,你會(huì)是一個(gè)好的架構(gòu)師。當(dāng)然窝剖,最好是都要思考一下啦麻掸。

*** Yarn 原生的API太底層,太復(fù)雜了 ***

如果你想愉快的開(kāi)發(fā)Yarn的應(yīng)用赐纱,那么對(duì)Yarn的API進(jìn)行一次封裝脊奋,是很有必要的。 Yarn為了靈活疙描,或者為了能夠滿足開(kāi)發(fā)者大部分的需求诚隙,底層交互的API就顯得比較原始了。自然造成開(kāi)發(fā)難度很大起胰。這個(gè)也不是我一個(gè)人覺(jué)得久又,現(xiàn)在Apache的twill,以及Hulu他們開(kāi)發(fā)的時(shí)候Adaptor那一層,其實(shí)都是為了解決這個(gè)問(wèn)題。那為什么我沒(méi)有用Twill呢籽孙,第一是文檔實(shí)在太少烈评,第二是有點(diǎn)復(fù)雜火俄,我不需要這么復(fù)雜的東西犯建。我覺(jué)得,Twill與其開(kāi)發(fā)這么多功能瓜客,真的不如好好寫(xiě)寫(xiě)文檔适瓦。

*** 最好是能開(kāi)發(fā)一個(gè)解決一類問(wèn)題的Framework ***

Yarn只是一個(gè)底層的資源管理和調(diào)度引擎。一般你需要基于之上開(kāi)發(fā)一套解決特定問(wèn)題的Framework谱仪。以Spark為例玻熙,他是解決分布式計(jì)算相關(guān)的一些問(wèn)題。而以我開(kāi)發(fā)的容器調(diào)度程序疯攒,其實(shí)是為了解決動(dòng)態(tài)部署Web應(yīng)用的嗦随。在他們之上,才是你的應(yīng)用敬尺。比如你要統(tǒng)計(jì)日志枚尼,你只要在Spark上開(kāi)發(fā)一個(gè)Application 。 比如你想要提供一個(gè)推薦系統(tǒng)砂吞,那么你只要用容器包裝下署恍,就能被容器調(diào)度程序調(diào)度部署。

所以通常而言蜻直,基于Yarn的分布式應(yīng)用應(yīng)該符合這么一個(gè)層次

Yarn -> Adapter -> Framework -> Application

Adapter 就是我第一條說(shuō)的盯质,你自個(gè)封裝了Yarn的API。 Framework就是解決一類問(wèn)題的編程框架概而,Application才是你真正要解決業(yè)務(wù)的系統(tǒng)呼巷。通過(guò)這種解耦,各個(gè)層次只要關(guān)注自己的核心功能點(diǎn)即可赎瑰。

*** 保證你上層的Framework/Application可以移植 ***

Spark是個(gè)典型,他可以跑在Mesos上王悍,也可以跑在Yarn上 ,還可以跑在自己上面(standalone),就是因?yàn)镾park的Framework不依賴于底層的Core,這個(gè)Core其實(shí)就是各個(gè)資源調(diào)度服務(wù)的適配層乡范。我封裝了Yarn后配名,上層的Framework是看不到的Yarn的API的,直接依賴YarnAdaptor,如果需要晋辆,我可以再開(kāi)發(fā)一套Mesos Adaptor渠脉。

這其實(shí)是上面兩條帶來(lái)的好處,因?yàn)橛辛薃daptor,上層的Framework可以不用綁死在某個(gè)資源調(diào)度引擎上瓶佳。而Framework則可以讓Applicaiton 無(wú)需關(guān)注底層調(diào)度的事情芋膘,只要關(guān)注業(yè)務(wù)即可。

另外,你費(fèi)盡心機(jī)開(kāi)發(fā)的Framework上为朋,你自然是希望它能跑在更多的平臺(tái)上臂拓,已滿足更多的人的需求,對(duì)吧习寸。

基于Yarn開(kāi)發(fā)容器調(diào)度系統(tǒng)的一些基本思路

首先我們需要了解兩個(gè)概念:

  • 啞應(yīng)用胶惰,所謂啞應(yīng)用指的是無(wú)法和分布式系統(tǒng)直接進(jìn)行交互,分布式系統(tǒng)也僅僅透過(guò)容器能進(jìn)行生命周期的控制霞溪,比如關(guān)閉或者開(kāi)啟的應(yīng)用孵滞。典型的比如MySQL,Nginx等這些基礎(chǔ)應(yīng)用。他們一般有自己特有的交互方式鸯匹,譬如命令行或者socket協(xié)議或者HTTP協(xié)議坊饶。

  • 伴生組件,因?yàn)橛辛藛?yīng)用的存在殴蓬,分布式系統(tǒng)為了能夠和這些應(yīng)用交互匿级,需要有一個(gè)代理。而這個(gè)代理和被代理的啞應(yīng)用染厅,具有相同的生命周期痘绎。典型的比如,某個(gè)服務(wù)被關(guān)停后糟秘,該事件會(huì)被分布式系統(tǒng)獲知简逮,分布式系統(tǒng)會(huì)將該事件發(fā)送給Nginx的伴生組件,伴生組件轉(zhuǎn)化為Nginx能夠識(shí)別的指令尿赚,將停止的服務(wù)從Nginx的ProxyBackend列表中剔除散庶。

在容器調(diào)度系統(tǒng)中,如果Yarn的NodeManager 直接去管理Docker則需要Yarn本身去做支持凌净,我覺(jué)得這是不妥的悲龟。Yarn的職責(zé)就是做好資源管理,分配冰寻,調(diào)度即可须教,并不需要和特定的某個(gè)技術(shù)耦合,畢竟Yarn是一個(gè)通用型的資源調(diào)度管理框架斩芭。我們只要開(kāi)發(fā)一套Framework,這個(gè)framework的slave節(jié)點(diǎn)其實(shí)是對(duì)應(yīng)容器的一個(gè)伴生對(duì)象轻腺,這樣我們就能透過(guò)這個(gè)framework對(duì)容器進(jìn)行管理,并且該framework還銜接了容器和Yarn划乖。 我們簡(jiǎn)單描述下他們的流程

  1. 用戶提交Application,申請(qǐng)資源
  2. Yarn 啟動(dòng)Framework 的master
  3. Yarn啟動(dòng)Framework 的 slave
  4. slave 連接上master,并且發(fā)送心跳贬养,從而master知道slave的狀況
  5. slave 啟動(dòng) docker,slave 與被啟動(dòng)的這個(gè)docker container 一一對(duì)應(yīng)
  6. slave 定時(shí)監(jiān)控container
  7. slave發(fā)現(xiàn)container crash,slave 自動(dòng)退出琴庵,yarn獲得通知误算,收回資源
  8. master 發(fā)現(xiàn)有節(jié)點(diǎn)失敗仰美,發(fā)出新的節(jié)點(diǎn)要求,重新在另外一臺(tái)服務(wù)器上啟動(dòng)slave,重復(fù)從2開(kāi)始的步驟

這里還有一個(gè)問(wèn)題儿礼,如果slave 被正常殺掉咖杂,可以通過(guò)JVM ShudownHook 順帶把container也關(guān)掉。 但是如果slave被kill -9 或者異常crash掉了蚊夫,那么就可能導(dǎo)致資源泄露了诉字。目前是這個(gè)信息是由master上報(bào)給集群管理平臺(tái),該平臺(tái)會(huì)定時(shí)清理这橙。你也可以存儲(chǔ)該信息奏窑,譬如放到Redis或者M(jìn)ySQL中导披,然后啟動(dòng)后臺(tái)清理任務(wù)即可屈扎。

了解了這個(gè)思路后,具體實(shí)施就變得簡(jiǎn)單了,就是開(kāi)發(fā)一個(gè)基于Yarn的master-slave 程序即可撩匕,然后slave去管理對(duì)應(yīng)的docker容器鹰晨,包括接受新的指令。master提供管理界面展示容器信息止毕,運(yùn)行狀態(tài)即可模蜡。

當(dāng)然,你還可以再開(kāi)發(fā)一套Framework B 專門和Nginx交互扁凛,這樣比如上面的系統(tǒng)做了節(jié)點(diǎn)變更忍疾,通知B的master,然后B的master 通過(guò)自己的伴生組件Slave 完成Nginx的更新谨朝,從而實(shí)現(xiàn)后端服務(wù)的自動(dòng)變更和通知卤妒。

現(xiàn)在看來(lái),是不是這種概念完美的覆蓋了應(yīng)用之間的交互呢字币?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末则披,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子洗出,更是在濱河造成了極大的恐慌士复,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件翩活,死亡現(xiàn)場(chǎng)離奇詭異阱洪,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)菠镇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門冗荸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人辟犀,你說(shuō)我怎么就攤上這事俏竞〕袼叮” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵魂毁,是天一觀的道長(zhǎng)玻佩。 經(jīng)常有香客問(wèn)我,道長(zhǎng)席楚,這世上最難降的妖魔是什么咬崔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮烦秩,結(jié)果婚禮上垮斯,老公的妹妹穿的比我還像新娘。我一直安慰自己只祠,他們只是感情好兜蠕,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著抛寝,像睡著了一般熊杨。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上盗舰,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天晶府,我揣著相機(jī)與錄音,去河邊找鬼钻趋。 笑死川陆,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蛮位。 我是一名探鬼主播较沪,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼土至!你這毒婦竟也來(lái)了购对?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤陶因,失蹤者是張志新(化名)和其女友劉穎骡苞,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體楷扬,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡解幽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了烘苹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片躲株。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖镣衡,靈堂內(nèi)的尸體忽然破棺而出霜定,到底是詐尸還是另有隱情档悠,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布望浩,位于F島的核電站辖所,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏磨德。R本人自食惡果不足惜缘回,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望典挑。 院中可真熱鬧酥宴,春花似錦、人聲如沸您觉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)顾犹。三九已至倒庵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間炫刷,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工郁妈, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留浑玛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓噩咪,卻偏偏與公主長(zhǎng)得像顾彰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胃碾,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容