我所了解的幾種持續(xù)集成方案

關(guān)鍵字:配置管理参咙,CI龄广,CD,QA

前言

和幾個(gè)TW的朋友共事一年多蕴侧,學(xué)到了很多陽(yáng)春白雪的東西择同,比如持續(xù)集成、DevOps净宵,以及敏捷云云敲才。
自以為可以出師裹纳,結(jié)果在實(shí)施的過(guò)程中遇到很大的阻力,大部分同學(xué)不理解CI的作用紧武,認(rèn)為這是變相的傳銷剃氧。
如何讓領(lǐng)導(dǎo)和程序員滿意才是一套持續(xù)集成系統(tǒng)成功實(shí)施的關(guān)鍵。

最簡(jiǎn)方案:GitHub + TravisCI + CodeCov + VPS

GitHub不僅僅是一個(gè)代碼托管網(wǎng)站阻星,更是全世界最大的同性交友社區(qū)朋鞍。替代方案:BitBuket
Travis CI可以用GitHub賬號(hào)登錄,有助于理解持續(xù)集成的理念妥箕,文檔是英文滥酥,但是很簡(jiǎn)單。替代方案circleci
VPS推薦Linode畦幢,順便搭建一個(gè)SS坎吻,但是由于某些原因,你可能還是需要阿里云宇葱。
代碼測(cè)試覆蓋率可以使用codecov(可選)瘦真。

優(yōu)點(diǎn)

  • 便宜
  • 完全不需要維護(hù)硬件。

缺點(diǎn)

  • 訪問(wèn)外網(wǎng)不穩(wěn)定贝搁。
  • GitHub、TravisCI和CodeCov都有收費(fèi)項(xiàng)目芽偏。

總結(jié)

適合可以開源的小項(xiàng)目雷逆,主要是用來(lái)開拓眼界。

初級(jí)方案:代碼托管服務(wù) + Jenkins + VPS

如果覺(jué)得GitHub網(wǎng)速太慢污尉,可以考慮使用國(guó)內(nèi)的替代品膀哲,比如開源中國(guó)的馬云,哦被碗,sorry某宪,是碼云,或者CSDN的CODE锐朴。它們的私有倉(cāng)庫(kù)是完全免費(fèi)的兴喂。
隨著業(yè)務(wù)的擴(kuò)大,Travis CI的問(wèn)題就開始顯露出來(lái):不穩(wěn)定焚志!特別是SSH通道衣迷。當(dāng)然,這不是Travis CI的錯(cuò)酱酬,你懂的……
這時(shí)候就可以考慮換成Jenkins了壶谒,在國(guó)內(nèi)芯急,持續(xù)集成基本就等同于Jenkins翅萤。
除非特殊用途,VPS也請(qǐng)選擇國(guó)內(nèi)的摧莽。
PS. 如果使用的是碼云,可以配套使用開源中國(guó)提供的SonarQube陨界,See:http://sonar.oschina.net/

優(yōu)點(diǎn)

  • 費(fèi)用低(只需要VPS的費(fèi)用)巡揍。

缺點(diǎn)

  • 賬號(hào)不通用,配置管理混亂普碎。

總結(jié)

適合沒(méi)有敏感信息的小項(xiàng)目吼肥。

萬(wàn)精油:GitLab + Jenkins + Nexus + SonarQube + VPS/VMWare

當(dāng)公司步入正軌以后,一般就會(huì)有一套OA系統(tǒng)麻车,比如基于LDAP的企業(yè)通訊錄缀皱。這個(gè)時(shí)候就需要統(tǒng)一的配置管理和一個(gè)配置管理員(CMO)的角色。
GitLab是比較成熟的解決方案动猬,完全可以替代GitHub啤斗,Code Review的時(shí)候挺好使的。
另外可以考慮增加構(gòu)件倉(cāng)庫(kù)Nexus OSS和代碼質(zhì)量檢查的平臺(tái)SonarQube赁咙。
Nexus私服大家應(yīng)該不陌生钮莲,缺點(diǎn)是沒(méi)有官方的LDAP插件,但是對(duì)于大部分開發(fā)人員來(lái)說(shuō)可以不關(guān)注彼水,我們可以把私服地址配在公司級(jí)Root POM崔拥。
SonarQube可以和Jenkins無(wú)縫集成,Jenkins的流水線應(yīng)該包括一個(gè)QA Job凤覆,如果掃描出致命或者嚴(yán)重Issue直接失敗链瓦。代碼質(zhì)量問(wèn)題應(yīng)該馬上解決,而不應(yīng)該留到Code Review盯桦。
PS. Jenkins慈俯、GitLab和SonarQube都可以通過(guò)LDAP進(jìn)行登錄。

優(yōu)點(diǎn)

  • 費(fèi)用適中拥峦。

缺點(diǎn)

  • 無(wú)明顯缺點(diǎn)贴膘。

總結(jié)

適合大部分的中小企業(yè)。

終極方案:自建CI/CD流水線

中大型企業(yè)不差錢略号,萬(wàn)事不求人刑峡,所以自建持續(xù)集成流水線就成為必然。
首先說(shuō)說(shuō)萬(wàn)精油方案的局限(不算是缺點(diǎn)):

  • Jenkins玄柠、Nexus還有SonarQube最大的共性就是如出一轍的插件系統(tǒng)氛琢,特別是前面兩個(gè),完全是基于文件系統(tǒng)(主要是xml)的随闪,當(dāng)接入的項(xiàng)目越來(lái)越多阳似,性能就會(huì)急劇下降。
  • 雖然可以通過(guò)LDAP登錄铐伴,但是畢竟是完全獨(dú)立的系統(tǒng)撮奏,無(wú)法做到單點(diǎn)登錄俏讹。
  • 風(fēng)格不統(tǒng)一,領(lǐng)導(dǎo)要看報(bào)表畜吊。

最簡(jiǎn)單的做法就是給這些系統(tǒng)加層皮泽疆,這也是很多企業(yè)或者部門的做法。不過(guò)依然無(wú)法解決性能問(wèn)題玲献。
現(xiàn)在來(lái)說(shuō)說(shuō)我所了解的一些方案:

  • Jenkins Job Builder
    OpenStack CI系統(tǒng)的核心殉疼,配合OpenStack自己的任務(wù)調(diào)度,把Jenkins做成了真正的分布式捌年。See: Understanding the OpenStack CI System瓢娜。
  • CloudBees
    差不多是Jenkins的商業(yè)版,最大的特點(diǎn)是礼预!哈哈眠砾,開玩笑,持續(xù)集成服務(wù)就沒(méi)有便宜的托酸。大致的做法就是workscpce共享高速磁盤褒颈。
  • Artifactory
    JFrog出品,可以用來(lái)替換Nexus励堡,原生支持LDAP谷丸、分布式,需要安裝數(shù)據(jù)庫(kù)应结,一般大公司直接找他們(一般和Jenkins一起)定制開發(fā)。
  • Go CD
    TW出品摊趾,號(hào)稱業(yè)界唯一能達(dá)到持續(xù)部署高度的平臺(tái)币狠,某為就有基于Go進(jìn)行定制開發(fā)游两。

優(yōu)點(diǎn)

  • 成本高昂砾层。

缺點(diǎn)

  • 無(wú)

總結(jié)

適合大中型企業(yè)。
---------EOF--------

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末贱案,一起剝皮案震驚了整個(gè)濱河市肛炮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宝踪,老刑警劉巖侨糟,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瘩燥,居然都是意外死亡秕重,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門厉膀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)溶耘,“玉大人二拐,你說(shuō)我怎么就攤上這事〉时” “怎么了百新?”我有些...
    開封第一講書人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)庐扫。 經(jīng)常有香客問(wèn)我饭望,道長(zhǎng),這世上最難降的妖魔是什么形庭? 我笑而不...
    開封第一講書人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任铅辞,我火速辦了婚禮,結(jié)果婚禮上碘勉,老公的妹妹穿的比我還像新娘巷挥。我一直安慰自己,他們只是感情好验靡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開白布倍宾。 她就那樣靜靜地躺著,像睡著了一般胜嗓。 火紅的嫁衣襯著肌膚如雪高职。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,488評(píng)論 1 302
  • 那天辞州,我揣著相機(jī)與錄音怔锌,去河邊找鬼。 笑死变过,一個(gè)胖子當(dāng)著我的面吹牛埃元,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播媚狰,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼岛杀,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了崭孤?” 一聲冷哼從身側(cè)響起类嗤,我...
    開封第一講書人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎辨宠,沒(méi)想到半個(gè)月后遗锣,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡嗤形,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年精偿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡笔咽,死狀恐怖墓阀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拓轻,我是刑警寧澤斯撮,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站扶叉,受9級(jí)特大地震影響勿锅,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜枣氧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一溢十、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧达吞,春花似錦张弛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至覆糟,卻和暖如春刻剥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背滩字。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工造虏, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人麦箍。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓漓藕,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親挟裂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子享钞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

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