軟體開發程序中,開發成員經常需要把自己作業集成到專案中,通常每個成員每天至少集成一次。如果專案較小,對外部的依賴較小,那么軟體集成可能不會是什么問題。但是目前很多軟體專案特別是互聯網專案面臨著需求不明確,系統架構復雜,任務分配混亂等一系列問題,從而給持續集成帶來許多麻煩。也給整個專案帶來不必要的風險。因此一個有效的持續集成系統越來越重要。

個推平臺是一個極其復雜的分布式系統,整個系統包含了 RPC 呼叫,高速快取,集群同步等各種復雜的場景。整個團隊只有二十來個人卻維護了近百個模塊的開發和測驗作業,如果沒有一套有效的機制,很難想象如何完成這些任務。持續集成在其中扮演了非常重要的角色,借助于 Git、Docker、Jenkins 以及 Nexus 等工具,我們搭建了自己的持續集成環境,并一步一步的摸索出了自己的最佳實踐,這篇文章將會和大家一起分享我們是如何利用這些技術提高團隊的生產力的。
個推持續集成系統的組成
使用git作為版本控制庫
相比于同類專案版本系統,git有一項非常顯著的優勢,就是版本分支(branch)的合并(merge)十分方便。
使用docker搭建測驗環境
作為一種新型的虛擬化方式,相對于傳統的虛擬化方式有著眾多的優勢。例如,docker虛擬容器的啟動可以在秒級實作,并且對系統資源的利用率很高。另外,docker的管理,遷移和擴展也更輕松有效。
使用jenkins作為持續集成服務器
Jenkins為開發人員提供了非常有效的持續集管理。其強大的插件系統和明確的構建邏輯,使得構建流程的創建非常簡便。
Docker在持續集成系統中的作用
測驗作為軟體專案重要的一環,一般都需要開發團隊搭建一套獨立的測驗系統。但作為持續集成的一個環節,此測驗系統又異于一般的測驗系統。主要原因為,持續集成測驗系統主要用來做回歸測驗,而且需要支持快速大量的代碼升級。基于docker的特性,以及持續集成的需求,個推采用docker為持續集成搭建了一整套測驗系統。
鏡像準備:docker 的運行基于鏡像檔案,而每個專案所需的鏡像檔案又不同。因此需要獨立分析每個專案的需求以及未來擴展需要,創建出不同版本的鏡像檔案。目前,個推主要有4大類鏡像,分別支持前端,后端,工具類等專案。以前端為例,個推采用了前后端分離的開發模式,因此此鏡像主要用來支持web 前端的服務運行。
服務包準備:為了能在docker里運行所需要的服務,需要docker實體中安裝相應的服務包(service package)。 一般有兩種方法,一種是將相應的服務包在鏡像檔案中安裝,另一種以docker 卷的形式動態映射到docker實體。 兩種方式有其優劣,第一種方式使得每次docker 容器的啟動非常迅捷,而第二種方式則更為靈活。這個需要根據不同的需求選擇合適的方式。
下圖為docker 在整個持續集成系統中的作用。Jenkins 作為主服務器將代碼和docker 統一的管理起來。

個推持續集成流程
下面以user模塊為例,對持續集成的流程進行闡述,如下圖所示:

從圖中可以看出,我們系統的git分支包括dev,master兩個分支:
dev:開發分支,開發人員維護,開發人員將最新代碼提交到這個分支,Jekins監視這個分支,任何代碼改變都會觸發自動化測驗
master:發布分支,這個分支上的版本是自動化測驗通過后的版本,且自動化打包監控這個分支
圖中的每個長方形代表一個Jenkins Job。下面將對每個Job進行說明:
? user: 監控user代碼庫的dev分支,當每次有新的代碼提交時,就會自動觸發構建任務。編譯代碼,同時生成code style,測驗覆寫率等關于代碼質量的報表。成功后將觸發user-docker任務。
? user-docker: 打包user工程,重啟user的docker實體以便于使用全新的user包。成功后將觸發testcase任務
? testcase: 驗收測驗,檢測改變是否滿足業務需求所定義的驗收條件。成功后將觸發marge任務
? merge:將user的dev分支merge到master分支
? user-pkg: 監控user代碼庫的master分支,當有代碼改變時,執行mvn package打包操作
經過上面的幾個步驟,從代碼提交到打包的整個程序就自動化起來了。
總結
目前越來越多的公司開始重視持續集成系統,但是缺乏定制化的系統真的能滿足復雜的需求嗎?當模塊之間的聯系越來越復雜,集成的頻率越來越大,運行環境的不斷升級 等等,缺乏定制的持續集成系統是否能達到預期,個推在docker 上找到了解決方案。 雖然仍然有許多挑戰,但隨著技術的升級和完善,我們侄訓越做越好。
uj5u.com熱心網友回復:
這篇應當發布到blog而不是論壇uj5u.com熱心網友回復:
參考這個看看怎么定制:http://blog.csdn.net/lee790608/article/details/51559970
本人QQ 280775561,微信JohnLee790608,有同路人可以一起探討。
uj5u.com熱心網友回復:
做推廣賣一個不被人待見的東西不宜啊。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/77305.html
標籤:Docker
上一篇:建設云平臺時,如何選擇云平臺?
下一篇:虛擬化在web應用中的一個探討
