在過去十年的時(shí)間里,持續(xù)集成(CI)和持續(xù)交付(CD)取得了巨大的進(jìn)步。DevOps的興起導(dǎo)致對CI/CD工具的需求,也快速增長?,F(xiàn)有的CI/CD解決方案一直在與時(shí)俱進(jìn),無數(shù)的新產(chǎn)品或新版本正在進(jìn)入DevOps領(lǐng)域。當(dāng)你有如此多的選擇時(shí),選擇正確的CI/CD工具,就很有必要。
在所有可用的CI/CD工具中,你應(yīng)該考慮的兩個(gè)工具是Jenkins和GitLab CI/CD。
以G2為例,Jenkins在G2上的平均評分為4.3星,有288條評論,而GitLab CI/CD在G2上的評分為4.4星,有270條評論。Jenkins于2011年發(fā)布,屬于CI/CD業(yè)務(wù),它一直是測試人員的首選。然而,自2014年以來,GitLab CI/CD一直以其先進(jìn)的功能受到越來越多人的注意。
作為DevOps測試專家,你需要根據(jù)項(xiàng)目,預(yù)算和其他要求仔細(xì)評估這些工具。為了幫助你,我將對Jenkins vs GitLab CI/CD進(jìn)行深入評估,以幫助你選擇適合你項(xiàng)目要求的CI/CD工具。
讓我們從基礎(chǔ)開始。
Jenkins介紹
Jenkins是著名的可擴(kuò)展的開源CI/CD工具,用于自動化部署。Jenkins完全用Java編寫,并在MIT許可下啟動。它具有一組強(qiáng)大的功能,可以自動執(zhí)行與軟件的構(gòu)建,測試,部署,集成和發(fā)布有關(guān)的任務(wù)??稍趍acOS,Windows和各種UNIX版本(例如OpenSUSE,Ubuntu,Red Hat等)上使用。除了通過本機(jī)安裝軟件包進(jìn)行安裝外,它還可以獨(dú)立安裝或作為Docker在任何有Java Runtime Environment(JRE)的計(jì)算機(jī)上安裝。
Jenkins團(tuán)隊(duì)還有一個(gè)名為Jenkins X的子項(xiàng)目,專門和Kubernetes一起使用。Jenkins X巧妙地集成了Helm,Jenkins CI/CD等工具。
使用Jenkins的一個(gè)優(yōu)點(diǎn)是腳本結(jié)構(gòu)合理,易于理解并且可讀性強(qiáng)。Jenkins團(tuán)隊(duì)已經(jīng)研發(fā)了大約1,000個(gè)插件,使該應(yīng)用程序可以與其他熟悉的技術(shù)融合在一起。
此外,還可以使用Credentials Command插件,這使得在腳本中添加身份驗(yàn)證憑據(jù)等變得容易且可行。
Jenkins開始運(yùn)行后,你還可以驗(yàn)證每個(gè)階段是否通過或失敗。但是,你無法在提供的圖形界面中檢查特定任務(wù)的狀態(tài)。
Jenkins:核心功能
Jenkins以易于設(shè)置,自動構(gòu)建過程以及文檔豐富而聞名。在進(jìn)行DevOps時(shí),Jenkins被認(rèn)為是非??煽康?,并且可能不必監(jiān)視整個(gè)構(gòu)建過程,而其他CI/CD工具則并非如此。讓我們看一下Jenkins提供的一些最重要的功能:
1.免費(fèi),開源且易于安裝
Jenkins可輕松用于macOS,Unix,Windows和平臺。它可以與Docker結(jié)合使用,可以為自動化任務(wù)帶來更高的一致性和效率。它也可以在Java容器(例如Apache Tomcat和GlassFish)中作為servlet運(yùn)行。文檔豐富,可以指導(dǎo)整個(gè)安裝過程。
2.豐富的插件生態(tài)系統(tǒng)
與其他CI/CD工具相比,Jenkins的插件生態(tài)系統(tǒng)更加成熟。目前,他們提供了1500多個(gè)插件。它使定制變得容易且有利可圖。因此,你無需購買昂貴的插件。
3.易于設(shè)置和配置
Jenkins設(shè)置和配置過程非常簡單,安裝過程僅需要一些步驟。Jenkins的升級過程也很輕松,直接。
4.社區(qū)活躍
如你所知,這是一個(gè)具有豐富插件生態(tài)系統(tǒng)的開源項(xiàng)目,所有插件和功能都得到了社區(qū)的廣泛支持。
5.提供REST API
Jenkins提供了RESTful接口以實(shí)現(xiàn)可擴(kuò)展性。具體參考,Jenkins API文檔。
6.并行執(zhí)行
Jenkins支持并行。你可以輕松地將其與不同的工具集成,并在構(gòu)建成功或失敗時(shí)獲得通知。開發(fā)人員甚至可以跨不同的虛擬機(jī)并行執(zhí)行多個(gè)構(gòu)建,從而提高效率。
7.分布式任務(wù)
它可以毫不費(fèi)力地運(yùn)行分布式任務(wù),即任務(wù)在不同的計(jì)算機(jī)上運(yùn)行。
GitLab CI/CD介紹
在所有CI/CD工具中,GitLab CI/CD無疑是最新的一種。它是內(nèi)置在GitLab CI/CD中的免費(fèi)且自托管的持續(xù)集成工具。GitLab CI/CD具有社區(qū)版本,并提供git存儲庫管理,問題跟蹤,代碼審查,Wiki等。組織可以在本地安裝GitLab CI/CD,并將其與Active Directory和LDAP服務(wù)器連接以進(jìn)行安全授權(quán)和身份驗(yàn)證。
GitLab CI/CD以前是一個(gè)獨(dú)立項(xiàng)目,于2015年9月與GitLab 8.0發(fā)行版集成。GitLab CI/CD提供了計(jì)劃,打包,SCM,發(fā)布,配置和檢查等功能。
GitLab CI/CD還提供了存儲庫,因此Gitlab CI/CD的集成非常簡單明了。
在使用GitLab CI/CD時(shí),包括一系列階段,這些階段將以精確的順序執(zhí)行。
每個(gè)任務(wù)都是一個(gè)階段的一部分,并且將在一個(gè)階段自動與其他任務(wù)并行運(yùn)行。你可以在階段內(nèi)檢查每個(gè)任務(wù)的狀態(tài)。這就是GitLab CI/CD與其他CI/CD工具的不同之處。
GitLab CI/CD:核心功能
GitLab CI/CD是用于DevOps測試的最受歡迎的CI/CD工具之一。GitLab CI/CD擁有強(qiáng)大的文檔,易于控制,良好的用戶體驗(yàn)。如果你不熟悉GitLab CI/CD,我將列出GitLab CI/CD的主要功能,這些功能將幫助你更好地了解它。
1.高可用性
GitLab CI/CD被廣泛使用,并且是最新的開源CI/CD工具之一。GitLab CI/CD的安裝和配置都很容易。它是內(nèi)置在GitLab中的免費(fèi)的自托管CI工具。
2. Jekyll插件支持
Jekyll插件是一個(gè)靜態(tài)網(wǎng)站生成器,具有對GitHub Pages的強(qiáng)大支持,它使構(gòu)建過程更簡單。Jekyll插件支持使用HTML文件和Markdown并根據(jù)你的布局偏好創(chuàng)建一個(gè)完全靜態(tài)的站點(diǎn)。通過編輯config.yml文件,可以輕松配置大多數(shù)Jekyll設(shè)置,例如,網(wǎng)站的插件和主題。
3.里程碑設(shè)置
里程碑是跟蹤問題,改進(jìn)一系列問題的絕佳方法。
4.可擴(kuò)展
自動擴(kuò)展縮放GitLab CI運(yùn)行程序,可以輕松管理并節(jié)省90%的EC2成本。這是必不可少的,尤其是對于并行的測試環(huán)境。
5.問題跟蹤和問題修復(fù)
由于其出色的問題跟蹤和問題修復(fù)功能,GitHub是眾多開源項(xiàng)目首選的CI/CD工具。為了實(shí)現(xiàn)簡單且無故障的監(jiān)控,測試結(jié)果顯示在GitHub UI上。
6.使用訪問控制管理Git存儲庫
你可以輕松地管理git存儲庫。你可以輕松地向單個(gè)存儲庫上的協(xié)作者授予寫/讀訪問權(quán)限,對該組織的存儲庫具有更精細(xì)的訪問控制。
7.活躍的社區(qū)支持
活躍的社區(qū)是GitLab CI/CD的主要優(yōu)點(diǎn)之一。所有支持都是開箱即用的,不需要在其他插件的安裝中進(jìn)行修改。
8.代碼審查和合并請求
GitLab CI/CD不僅用于構(gòu)建代碼,而且還用于檢查或?qū)彶榇a。它允許通過合并請求來改善協(xié)作。
Jenkins 和GitLab CI/CD 對比
Jenkins和GitLab CI/CD都擅長于自己的工作,并且擁有自己的技術(shù)支持。
特征 |
Jenkins |
GITLAB CI/CD |
開源或商業(yè) |
開源的 |
開源的 |
產(chǎn)品類別 |
自托管/內(nèi)部部署 |
自托管/內(nèi)部部署 |
內(nèi)置CI/CD |
Jenkins支持CI/CD |
不需要為CI/CD安裝任何東西,它具有內(nèi)置功能 |
獨(dú)特的功能 |
插件 |
AutoDevOps /允許將CI和代碼管理保持在同一位置。 |
產(chǎn)品種類 |
自托管/本地 |
SaaS /本地 |
支持SLA |
否 |
是 |
安裝與安裝 |
簡單 |
簡單 |
自托管選項(xiàng) |
開源和自我托管是使用它的唯一方法 |
是 |
建立管道 |
通過Jenkins Pipeline DSL的定制管道 |
是 |
應(yīng)用程序性能監(jiān)控 |
不提供分析性能的功能 |
將顯示所有已部署應(yīng)用程序的性能指標(biāo) |
生態(tài)系統(tǒng) |
1000多個(gè)社區(qū)插件 |
是 |
全面的API |
具有全面的API功能。 |
提供用于軟件項(xiàng)目中更深層集成的API。 |
特殊語言支持:JavaScript |
是 |
是 |
整合方式 |
允許與其他工具(例如:Slack,GitHub)集成。 |
可訪問大量第三方集成,最著名的是GitHub和Kubernetes。 |
CI/CD部署儀表板 |
部分支持 |
每個(gè)用戶可以根據(jù)流水線歷史記錄和項(xiàng)目中的最新狀態(tài),更改儀表板。 |
API |
是 |
是的,提供了REST API和GraphQL API |
代碼質(zhì)量 |
通過Sonarqube插件提供代碼質(zhì)量檢查 ,另外還可以使用不同的插件來驗(yàn)證代碼質(zhì)量。 |
Gitlab還提供了檢查代碼質(zhì)量的功能。 |
Jenkins和GitLab CI/CD之間的區(qū)別
既然你已經(jīng)看到了Jenkins與GitLab CI/CD的功能比較,現(xiàn)在是時(shí)候找出兩種DevOps測試工具之間的差異了。這些差異將幫助你了解Jenkins vs GitLab CI/CD之戰(zhàn)的真正原因。
1.借助Gitlab CI/CD,你可以完全通過分支和其他方面來控制Git存儲庫,以確保代碼免受威脅。但是,在Jenkins中,你只能控制存儲庫,不允許完全控制分支。
2.Jenkins是“內(nèi)部托管”的,并且是“免費(fèi)開放源代碼”,這就是編碼人員偏愛它的原因。另一方面,Gitlab CI/CD是“自托管”和“免費(fèi)”的,這就是開發(fā)人員更喜歡它的原因。
3.在Gitlab CI/CD中,每個(gè)項(xiàng)目都有一個(gè)跟蹤器,該跟蹤器將跟蹤問題并執(zhí)行代碼審查以提高效率。在使用Jenkins工具時(shí),它更改了支持方式,并簡化了安裝和配置過程。
Jenkins和GitLab CI/CD的功能差異
Jenkins的優(yōu)點(diǎn)
豐富的插件庫
自托管
輕松調(diào)試
易于設(shè)置節(jié)點(diǎn)
易于部署代碼
很好的憑證管理
功能靈活多變
支持不同的語言
非常直觀
Jenkins的缺點(diǎn)
復(fù)雜的插件集成
配置多
缺乏對流水線的整體跟蹤的分析
Gitlab CI/CD的優(yōu)點(diǎn)
更好的Docker集成
擴(kuò)展跑簡單
分階段并行執(zhí)行任務(wù)
并發(fā)運(yùn)行
合并請求
任務(wù)添加容易
易于處理沖突
良好的安全和隱私政策
Gitlab CI/CD的缺點(diǎn)
需要為每個(gè)任務(wù)定義組件。
在實(shí)際合并發(fā)生之前,不能測試分支的合并狀態(tài)。
目前尚不支持,一個(gè)大階段中包含幾個(gè)小階段。
Jenkins和GitLab CI/CD:應(yīng)該首選哪種CI/CD工具?
Jenkins和GitLab CI/CD都有各自的優(yōu)缺點(diǎn),你在這兩種CI/CD工具之間的最終選擇,完全取決于項(xiàng)目要求和規(guī)格。這些CI/CD工具中的每一個(gè)都有其自身的優(yōu)缺點(diǎn),Jenkins用于持續(xù)集成,而Gitlab CI/CD用于代碼協(xié)作和版本控制。
除了突出的功能,你還應(yīng)該瀏覽價(jià)格表和組織內(nèi)部熟練程度,才能為DevOps挑選最佳的CI/CD工具。