持續(xù)部署的發(fā)展之路

我們無(wú)數(shù)次聽(tīng)到這類(lèi)的抱怨:管理層不會(huì)去做、代碼太過(guò)混亂凑保、項(xiàng)目太大、有太多的監(jiān)管障礙喜德。由此種種,對(duì)于許多企業(yè)來(lái)說(shuō)垮媒,在持續(xù)集成/持續(xù)部署的道路已步履蹣跚舍悯,但不得不說(shuō),仍有一部分企業(yè)做到了睡雇。

以Michiel Rook在2016 年的DevOps大會(huì)上的演講為例萌衬,一起來(lái)看看關(guān)于持續(xù)部署的發(fā)展之旅。他們的項(xiàng)目被稱(chēng)為“San Diego Project”它抱,但他們公司內(nèi)部卻被稱(chēng)為“大泥球”秕豫,因?yàn)樗拇a庫(kù)相當(dāng)?shù)鼗靵y。

下圖是實(shí)施持續(xù)部署前的狀態(tài):

該項(xiàng)目的壓力很大观蓄。皆來(lái)源于它純手動(dòng)發(fā)布混移,脆弱的測(cè)試,頻繁的宕機(jī)以及問(wèn)題不斷侮穿。這個(gè)項(xiàng)目團(tuán)隊(duì)大約由16人組成歌径,但他們對(duì)修改現(xiàn)有代碼并沒(méi)有什么信心。

他們知道需要做什么亲茅,所以他們?cè)O(shè)定了以下目標(biāo):

減少問(wèn)題

減少周期時(shí)間

提高生產(chǎn)效率

提高積極性

他們采取的方法是:整體修改回铛,建立一個(gè)代理并添加一個(gè)服務(wù)狗准,然后不斷地增加服務(wù),直到這個(gè)整體被取代茵肃。

他們以如下原則來(lái)指導(dǎo)這次持續(xù)部署之旅:

應(yīng)用strangler模式

使用API的第一個(gè)方法

為每個(gè)domain設(shè)置一個(gè)服務(wù)

遷移單個(gè)頁(yè)面

建立負(fù)載平衡器后的服務(wù)

訪(fǎng)問(wèn)遺留數(shù)據(jù)庫(kù)

實(shí)施持續(xù)部署

運(yùn)用docker

開(kāi)發(fā)前端作為服務(wù)

從持續(xù)集成開(kāi)始:開(kāi)發(fā)和構(gòu)建/測(cè)試腔长,每次都產(chǎn)生一個(gè)工件。持續(xù)交付:從構(gòu)建/測(cè)試到驗(yàn)收再到生產(chǎn); 進(jìn)入生產(chǎn)階段是一個(gè)手動(dòng)的過(guò)程免姿,但代碼是可部署的饼酿。最后榕酒,當(dāng)整個(gè)流程實(shí)現(xiàn)自動(dòng)化時(shí)胚膊,就達(dá)到持續(xù)部署的目標(biāo)了。

關(guān)于持續(xù)部署的優(yōu)點(diǎn)有以下幾點(diǎn):

小步推進(jìn)

早期反饋

減少循環(huán)時(shí)間

風(fēng)險(xiǎn)減低

實(shí)驗(yàn)室環(huán)境

Michiel的項(xiàng)目落地后想鹰,他總結(jié)了幾個(gè)實(shí)現(xiàn)持續(xù)部署的關(guān)鍵方面紊婉,如下:

l直接提交到Master沒(méi)有分支辑舷。我們都不希望延遲集成喻犁,且濫用版本控制功能分離。另外何缓,分支上的所有內(nèi)容都會(huì)增加沖突和延遲集成的風(fēng)險(xiǎn)肢础。

每一次提交都要投入生產(chǎn)。

使用配對(duì)編碼進(jìn)行代碼審查碌廓。這需要約束传轰,但所有的開(kāi)發(fā)人員都需要成對(duì)進(jìn)行,混合搭配有經(jīng)驗(yàn)的開(kāi)發(fā)人員谷婆。

嚴(yán)把質(zhì)量關(guān)慨蛙。確保大量測(cè)試和代碼覆蓋率。

功能切換和A/B Test纪挎。確保一部分開(kāi)發(fā)人員可以看到版本信息期贫,一部分人不能看到,并促進(jìn)A / B測(cè)試异袄。但一定要把人員數(shù)量保持在一個(gè)合理的范圍內(nèi)通砍。

Dashboards顯示是部署的關(guān)鍵烤蜕,通過(guò)它我們可以獲取很多信息封孙,比如KPI、構(gòu)建時(shí)間玖绿、頁(yè)面加載時(shí)間敛瓷、訪(fǎng)問(wèn)者數(shù)量、A/B Test結(jié)果斑匪,等等呐籽。

DevOps锋勺。心態(tài)是一種文化;dev和ops之間并無(wú)太多隔閡狡蝶。團(tuán)隊(duì)內(nèi)部都擁有所有權(quán)庶橱,但這并不意味著每個(gè)人都知道所有事。

自動(dòng)化可重復(fù)的事贪惹。如果同樣的事你需要做兩次苏章,那說(shuō)明你已經(jīng)浪費(fèi)了時(shí)間。

連續(xù)測(cè)試奏瞬。使用單元測(cè)試和冒煙測(cè)試來(lái)查看服務(wù)是否存在枫绅,并持續(xù)監(jiān)控。探索性的測(cè)試很重要硼端,因?yàn)槟銓⒗^續(xù)測(cè)試最關(guān)鍵的路徑并淋。

管道作為代碼。自動(dòng)化流水線(xiàn)珍昨。最后县耽,部署起來(lái)是這樣的:

反饋–及時(shí)的反饋很重要,因?yàn)镈evOps是在此基礎(chǔ)之上建立的镣典。舉個(gè)例子兔毙,Michiel這個(gè)項(xiàng)目上有一個(gè)閃爍的紅光,這表示失敗兄春。所以不管什么時(shí)候澎剥,及時(shí)反饋都是工作中的第一要事。

Michiel的項(xiàng)目時(shí)間跨度有一年之久神郊。最終肴裙,他們將每個(gè)服務(wù)的構(gòu)建時(shí)間減少到不到10分鐘,顯著改善了頁(yè)面加載時(shí)間涌乳,同時(shí)他們自己也增加了自信心和加快了速度等蜻懦。明白了團(tuán)隊(duì)需要接受和改變的重要性的真理。同時(shí)夕晓,他們還了解到宛乃,與業(yè)務(wù)優(yōu)先級(jí)一致是關(guān)鍵,確保擁有一定工作經(jīng)驗(yàn)的員工亦是至關(guān)重要蒸辆,限制功能切換同樣至關(guān)緊要征炼。

總的來(lái)說(shuō),Michiel和他的團(tuán)隊(duì)實(shí)現(xiàn)了持續(xù)部署躬贡。在他的演講結(jié)束時(shí)谆奥,Michiel也提到了他的無(wú)奈,想要取代的遺留系統(tǒng)仍在服務(wù)中拂玻。所以持續(xù)部署這條路還很長(zhǎng)酸些,但值得去做宰译。

關(guān)于Ghostcloud

Ghostcloud(中文名:精靈云)坐落于成都天府軟件園,是成都高新區(qū)重點(diǎn)扶持企業(yè)魄懂,國(guó)內(nèi)首批從事容器虛擬化研發(fā)的企業(yè)沿侈,是西南地區(qū)唯一一家基于Docker的云計(jì)算服務(wù)商,為企業(yè)級(jí)行業(yè)客戶(hù)提供針對(duì)互聯(lián)網(wǎng)化市栗、私有云管理平臺(tái)缀拭、大數(shù)據(jù)業(yè)務(wù)基礎(chǔ)架構(gòu)的平臺(tái)服務(wù)。

Ghostcloud因容器技術(shù)而生填帽,以最新容器技術(shù)Docker為基礎(chǔ)蛛淋,為適應(yīng)不同行業(yè)客戶(hù)需求,全自主研發(fā)了一套調(diào)度引擎框架Newben盲赊,且全方位適配Kubernetes主流開(kāi)源調(diào)度引擎铣鹏,也是國(guó)內(nèi)率先實(shí)現(xiàn)雙調(diào)度引擎的企業(yè)敷扫,是一流的企業(yè)級(jí)容器云服務(wù)專(zhuān)家哀蘑。Ghostcloud推出了企業(yè)級(jí)容器云PaaS/CaaS平臺(tái),命名為EcOS(EnterpriseContainer Operation System)葵第。Ghostcloud將EcOS平臺(tái)與微服務(wù)/DevOps相融合绘迁,運(yùn)用至企業(yè)IT系統(tǒng)的全生命周期的開(kāi)發(fā)、測(cè)試卒密、運(yùn)維及發(fā)布流程中缀台,致力于為多個(gè)領(lǐng)域企業(yè)向“互聯(lián)網(wǎng)+”轉(zhuǎn)型提供針對(duì)互聯(lián)網(wǎng)化、私有云管理平臺(tái)哮奇、大數(shù)據(jù)業(yè)務(wù)基礎(chǔ)架構(gòu)的平臺(tái)服務(wù)膛腐,幫助企業(yè)級(jí)客戶(hù)降低成本、提升效率鼎俘、簡(jiǎn)化運(yùn)維及產(chǎn)品部署哲身,并提升系統(tǒng)的可靠性和安全性。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末贸伐,一起剝皮案震驚了整個(gè)濱河市勘天,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌捉邢,老刑警劉巖脯丝,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異伏伐,居然都是意外死亡宠进,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)藐翎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)材蹬,“玉大人潦匈,你說(shuō)我怎么就攤上這事∽迹” “怎么了茬缩?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)吼旧。 經(jīng)常有香客問(wèn)我凰锡,道長(zhǎng),這世上最難降的妖魔是什么圈暗? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任掂为,我火速辦了婚禮,結(jié)果婚禮上员串,老公的妹妹穿的比我還像新娘勇哗。我一直安慰自己,他們只是感情好寸齐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布欲诺。 她就那樣靜靜地躺著,像睡著了一般渺鹦。 火紅的嫁衣襯著肌膚如雪扰法。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天毅厚,我揣著相機(jī)與錄音塞颁,去河邊找鬼。 笑死吸耿,一個(gè)胖子當(dāng)著我的面吹牛祠锣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播咽安,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼伴网,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了板乙?” 一聲冷哼從身側(cè)響起是偷,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎募逞,沒(méi)想到半個(gè)月后蛋铆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡放接,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年刺啦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纠脾。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡玛瘸,死狀恐怖蜕青,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情糊渊,我是刑警寧澤右核,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站渺绒,受9級(jí)特大地震影響贺喝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宗兼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一躏鱼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧殷绍,春花似錦染苛、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至镰烧,卻和暖如春拢军,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背怔鳖。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留固蛾,地道東北人结执。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像艾凯,于是被迫代替她去往敵國(guó)和親献幔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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

  • 轉(zhuǎn)載本文需注明出處:微信公眾號(hào)EAWorld趾诗,違者必究蜡感。 本文目錄: 一、企業(yè)應(yīng)用的部署發(fā)展 二恃泪、普元容器云與De...
    72a1f772fe47閱讀 911評(píng)論 0 3
  • 前言 DevOps方案實(shí)施在互聯(lián)網(wǎng)行業(yè)中已經(jīng)相對(duì)成熟了郑兴,而在游戲行業(yè)中還處在起步的初級(jí)階段(據(jù)個(gè)人了解的身邊游戲公...
    云時(shí)代構(gòu)架楊彪閱讀 2,560評(píng)論 0 8
  • 自微信出現(xiàn)后情连,朋友圈時(shí)不時(shí)就會(huì)被刷爆,有的是秀恩愛(ài)虐狗的览效、有的是奢飾品炫富的却舀、還有的是出門(mén)旅游炫生活的虫几。面對(duì)春風(fēng)十...
    想走走閱讀 359評(píng)論 0 0
  • 余笙一路跑回太師府,喘的上氣不接下氣挽拔,把青羅甩了老遠(yuǎn)去辆脸,門(mén)口的守衛(wèi)一見(jiàn)余笙,焦急地與她道:“小姐螃诅,您可回來(lái)了每强,...
    嚶語(yǔ)喃喃sherry閱讀 442評(píng)論 0 1
  • 1.愛(ài)在旅途 這部劇雖然是2010年熱播的,但是是我百看不厭的一部劇州刽,女主也是我很喜歡的泰國(guó)女星空执,女主為了尋找父親...
    wei_waou閱讀 552評(píng)論 0 1