故障演練之一 CI 系統(tǒng)中的 jenkins master

? ? ? ?由于最近線上故障頻出篡帕,公司決定對(duì)現(xiàn)有各個(gè)核心系統(tǒng)做故障演練耗拓,來(lái)加強(qiáng)核心系統(tǒng)的健壯性和可用性。我們演練的場(chǎng)景很簡(jiǎn)單彰檬,模擬單機(jī)房掛掉伸刃,所有的服務(wù)仍然可用谎砾。CI 作為各個(gè)業(yè)務(wù)系統(tǒng)所以依賴的核心組件,它的可用性是一定要嚴(yán)格保證的捧颅。 CI 中的 jenkins master 當(dāng)然也是我們組演練的重中之重景图。而在這之前 jenkins master 都是單點(diǎn)運(yùn)行的碉哑,可能運(yùn)氣比較好挚币,還沒(méi)有出過(guò)事故 ......

? ? ? ?為了落實(shí)公司的故障演練計(jì)劃,我們針對(duì)當(dāng)前系統(tǒng)的 jenkins master 做了 active/passive 模式的 HA 方案扣典,

? ? ? 具體如下:

? ? ? 討論方案前妆毕,讓我們先來(lái)回顧下 jenkins 的存儲(chǔ)模型,? jenkins 使用的是本地文件存儲(chǔ),所有數(shù)據(jù)都存儲(chǔ)在環(huán)境變量?JENKINS_HOME?對(duì)應(yīng)的目錄贮尖。

? ? ? ? jenkins 啟動(dòng)時(shí)會(huì)把本地文件中的數(shù)據(jù)加載到內(nèi)存笛粘,在這之后配置的變更都是先寫內(nèi)存,然后異步寫磁盤湿硝。也就是說(shuō)一旦Jenkins啟動(dòng)薪前,就再也不會(huì)嘗試從磁盤重新加載了。假設(shè)我們從磁盤中讀取了10個(gè)任務(wù)关斜,如果有從Jenkins UI頁(yè)面或者API提交修改任務(wù)的請(qǐng)求序六,那么Jenkins會(huì)去讀內(nèi)存中的任務(wù)配置信息,然后修改內(nèi)存數(shù)據(jù)蚤吹,再異步刷新到磁盤上。

? ? ? ? 也就是說(shuō) jenkins master 是有狀態(tài)的随抠,它依賴本地文件裁着。本地文件是可以放到共享存儲(chǔ)來(lái)解決,但是內(nèi)存中的狀態(tài)數(shù)據(jù)是拆不出來(lái)的拱她《郏看了一些其他公司的 jenkins master HA 方案, 有使用 pacemaker 和 gearman 等秉沼,但是這些架構(gòu)本身也比較復(fù)雜桶雀,它們自身也要保證HA,復(fù)雜度增加了很多唬复,因此我們也沒(méi)有考慮這些架構(gòu)矗积。

? ? ? ? 為了解決上面的問(wèn)題,我們?cè)跇I(yè)務(wù)端做了下改變敞咧,所有的 job 有個(gè)統(tǒng)一的模版棘捣,如果請(qǐng)求發(fā)現(xiàn) job 不存在,那我們就用模版新建一個(gè) job, 然后觸發(fā)運(yùn)行休建。業(yè)務(wù)只關(guān)系構(gòu)建結(jié)果乍恐,在哪個(gè)節(jié)點(diǎn)上構(gòu)建评疗,通過(guò)哪個(gè) master 分配,其實(shí)都是沒(méi)有影響的茵烈。這也間接的解了 jenkins 中 job 的同步問(wèn)題百匆,同時(shí)也讓使得上面的 active/passive 架構(gòu)有意義。

? ? ? ?總結(jié)一下呜投,jenkins 的 HA 是有很多解法的加匈,重要的是結(jié)合自己的場(chǎng)景。期望 jenkins 社區(qū)可用為用戶解決 HA 這個(gè)大問(wèn)題宙彪,讓 jenkins 更易用, 更強(qiáng)大矩动。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市释漆,隨后出現(xiàn)的幾起案子悲没,更是在濱河造成了極大的恐慌,老刑警劉巖男图,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件示姿,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡逊笆,警方通過(guò)查閱死者的電腦和手機(jī)栈戳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)难裆,“玉大人子檀,你說(shuō)我怎么就攤上這事∧烁辏” “怎么了褂痰?”我有些...
    開(kāi)封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)症虑。 經(jīng)常有香客問(wèn)我缩歪,道長(zhǎng),這世上最難降的妖魔是什么谍憔? 我笑而不...
    開(kāi)封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任匪蝙,我火速辦了婚禮,結(jié)果婚禮上习贫,老公的妹妹穿的比我還像新娘逛球。我一直安慰自己,他們只是感情好沈条,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布需忿。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪屋厘。 梳的紋絲不亂的頭發(fā)上涕烧,一...
    開(kāi)封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音汗洒,去河邊找鬼议纯。 笑死,一個(gè)胖子當(dāng)著我的面吹牛溢谤,可吹牛的內(nèi)容都是我干的瞻凤。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼世杀,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼阀参!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起瞻坝,我...
    開(kāi)封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蛛壳,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后所刀,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體衙荐,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年浮创,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忧吟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡斩披,死狀恐怖溜族,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情垦沉,我是刑警寧澤斩祭,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站乡话,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏耳奕。R本人自食惡果不足惜绑青,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望屋群。 院中可真熱鬧闸婴,春花似錦、人聲如沸芍躏。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至庇楞,卻和暖如春榜配,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吕晌。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工蛋褥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人睛驳。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓烙心,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親乏沸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子淫茵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345