推薦:2019年十佳DevOps工具
DevOps落地重要的一方面是選好工具集,本文介紹了最流行的DevOps工具。
開發(fā)和運(yùn)維的集成翻開了軟件開發(fā)的全新篇章。如果你還是DevOps的新手,或者正在尋求改進(jìn)已有流程的方法,那么第一道關(guān)卡就是調(diào)研哪些工具最適合你的團(tuán)隊。
本文整理了工具列表,為大家選擇所需的工具提供詳實的參考信息。讓我們一起看看從自動化build工具到應(yīng)用程序性能監(jiān)控平臺領(lǐng)域里,十大最佳DevOps工具是哪些吧。
1. Gradle
DevOps工具集需要一種可靠的build工具。Apache Ant和Maven統(tǒng)治著自動化build工具市場很多年,但是 Gradle 在2009年現(xiàn)身,從那時起它就邁著穩(wěn)定增長的步伐越來越流行。Gradle的功能很強(qiáng)大,允許用戶用Java,C++,Python或者其他語言編程。各種流行的IDE,比如Netbeans,Eclipse以及Intellij IDEA也都支持Gradle。如果這還無法說服你使用它,那么還有一點(diǎn)可能有所幫助,Google也選擇它作為Andriod Studio的 正式build工具 。
Maven和Ant使用XML配置,Gradle則引入了一種基于Groovy的DSL來描述build。在2016年,Gradle團(tuán)隊還發(fā)布了一種 基于Kotlin的DSL ,因此用戶現(xiàn)在也可以用Kotlin來編寫build的腳本。這意味著Gradle的學(xué)習(xí)需要一定的時間,如果你以前用過Groovy,Kotlin或其他JVM語言的話,那么會有助于Gradle的快速掌握。除此之外,Gradle使用Maven的repository格式,因此如果使用過Maven的話對Gradle的依賴管理也會比較熟悉。還可以 將Ant build導(dǎo)入 進(jìn)Gradle。
Gradle最好的設(shè)計是 增量build ,因此可以節(jié)省大量的編譯時間。根據(jù)Gradle的 性能報告 ,它比Maven快100倍。這樣的性能優(yōu)勢一部分來源于這種增量設(shè)計,另外也得益于Gradle的 build緩存 和 daemon 。build緩存重用task的輸出,而Gradle的Daemon將build的信息儲存在內(nèi)存里,可以在多個build間共享。
總的來說,Gradle讓快速交付成為可能,也讓配置更加靈活。
2. Git
Git 是最流行的DevOps工具之一,在軟件界使用廣泛。它是一種分布式SCM(源碼管理)工具,遠(yuǎn)程團(tuán)隊和開源貢獻(xiàn)者都很喜歡它。Git讓用戶可以跟蹤自己開發(fā)工作的進(jìn)度。用戶可以保存自己源碼的不同版本,并且在需要的時候切回之前的版本。它也很適合做實驗,因為可以創(chuàng)建單獨(dú)的分支,在需要的時候僅僅merge新特性。
要將Git和DevOps工作流集成起來,還需要維護(hù)repository,團(tuán)隊成員可以向其中push各自的工作。目前,兩大最佳在線的Git repo托管服務(wù)是 GitHub 和 Bitbucket 。GitHub更有名氣,但是Bitbucket給小團(tuán)隊(不超過五個成員)提供免費(fèi)不受限的私有repo。使用GitHub,用戶僅僅可以免費(fèi)訪問公有的repo——當(dāng)然這對于很多項目來說仍然是很好的解決方案。
GitHub和Bitbucket都有很好的集成。比如,用戶可以將它們和Slack集成,這樣團(tuán)隊的每個人都能在有任意commit時收到通知。
3. Jenkins
Jenkins 是很多軟件開發(fā)團(tuán)隊在走向DevOps時會用的自動化工具。它是開源的CI/CD服務(wù)器,幫助用戶自動化交付流水線的不同階段。Jenkins之所以流行的主要原因是其巨大的插件生態(tài)系統(tǒng)。目前,它提供 1000多個插件 ,因此它可以和幾乎所有DevOps工具(從Docker到Puppet)集成。
使用Jenkins,用戶可以搭建并且根據(jù)實際需要自定義自己的CI/CD流水線。 Jenkins文檔 里介紹了如下示例。這僅僅是一種可能的實現(xiàn)。看著很不錯,不是嗎?
使用Jenkins很容易 ,它在Windows,Mac OS X和Linux上開箱即用。很容易就可以 使用Docker安裝它 。用戶可以通過瀏覽器搭建并且配置Jenkins服務(wù)器。如果你是第一次使用它,可以選擇安裝最常用的插件。當(dāng)然也可以創(chuàng)建自定義配置。
使用Jenkins,用戶可以盡快迭代并部署新代碼。它還幫助用戶度量流水線里每一步是否成功。我聽到有人抱怨Jenkins很“丑陋”且并不直觀的UI。但是,我仍舊可以很容易地找到需要的所有東西。
4. Bamboo
Bamboo 是Atlassian的CI/CD服務(wù)器解決方案,很多特性和Jenkins類似。它們都是流行的DevOps工具,幫助用戶自動化發(fā)布流水線,從build到部署。但是,Jenkins是開源的,Bamboo是收費(fèi)的。因此,這里永恒的問題是,有免費(fèi)軟件時有必要選擇收費(fèi)軟件嗎?這取決于你的經(jīng)費(fèi)和目標(biāo)。
Bamboo有很多預(yù)構(gòu)建的功能,而這些功能在Jenkins里得自己手動搭建。這也正是Bamboo的插件更少的原因(大概100個,Jenkins有1000+個)。實際上,你并不需要Bamboo的很多插件,因為它帶著很多開箱可用的功能。
Bamboo和其他Atlassian產(chǎn)品,比如Jira和Bitbucket無縫集成。用戶還可以訪問內(nèi)建的Git和Mercurial分支工作流及測試環(huán)境。總之,Bamboo可以節(jié)省很多配置的時間。它的UI也更為直觀,有提示,自動補(bǔ)全和其他有用的特性。
5. Docker
Docker 在2013年發(fā)布之后已經(jīng)成為了首屈一指的容器平臺,并且仍然在持續(xù)改進(jìn)。它是最重要的DevOps工具之一。Docker在科技界掀起了容器化的潮流,主要是因為它讓分布式開發(fā)成為可能,并且自動化了應(yīng)用程序的部署。它將應(yīng)用程序隔離成單獨(dú)的容器,因此應(yīng)用變得更加便攜也更為安全。Docker應(yīng)用程序也獨(dú)立于OS以及平臺。用戶可以使用Docker容器代替虛擬機(jī),比如VirtualBox。
我最喜歡Docker的一點(diǎn)是用戶無需擔(dān)心依賴管理??梢詫⑺幸蕾嚧虬M(jìn)應(yīng)用程序的容器,并將所有的東西當(dāng)做獨(dú)立的單元交付。然后,用戶可以很輕松地在任意機(jī)器或者平臺上運(yùn)行這個應(yīng)用程序。
Docker也和 Jenkins 以及 Bamboo 集成。如果你將自動化服務(wù)器和Docker搭配使用,可以進(jìn)一步改進(jìn)交付工作流。另外,Docker也很適用于云計算。最近幾年,所有主流的云供應(yīng)商,比如AWS,Google Cloud,都已經(jīng)支持Docker。因此,如果你計劃云遷移,那么Docker可以幫助簡化這一進(jìn)程。
6. Kubernetes
今年,每個人都在談?wù)?Kubernetes 。它是容器編排平臺,將容器化推進(jìn)到下一個層面。它可以使用Docker或者其他替代產(chǎn)品。Kubernetes仍然很新;2015年才推出第一個版本。它由一些Google的工程師創(chuàng)建,他們想找到管理大規(guī)模容器的方案。使用Kubernetes,用戶可以將容器組織成邏輯單元。
如果你只有幾個容器,那么可能并不需要容器編排平臺。但是,當(dāng)系統(tǒng)達(dá)到一定級別的復(fù)雜度,需要擴(kuò)展資源的時候,這就是合理的下一步。Kubernetes讓用戶可以自動化管理上百個容器的過程。
使用Kubernetes,無需將容器化的應(yīng)用程序綁定到某個單獨(dú)的機(jī)器里。相反,你可以將它部署到一個機(jī)器集群里,Kubernetes會自動化分發(fā)并在整個集群里調(diào)度容器。
一個Kubernetes集群包含一個master和幾個worker節(jié)點(diǎn)。master節(jié)點(diǎn)實現(xiàn)預(yù)定義的規(guī)則,并且將容器部署到worker節(jié)點(diǎn)上。Kubernetes負(fù)責(zé)所有一切。比如,它注意到某個worker節(jié)點(diǎn)下線了,就會將其上的容器重新分發(fā)到別的節(jié)點(diǎn)上。
7. Puppet企業(yè)版
Puppet Enterprise 是一個跨平臺的配置管理平臺。它讓用戶可以將基礎(chǔ)架構(gòu)當(dāng)做代碼來管理。因為它自動化了基礎(chǔ)架構(gòu)管理,用戶可以更快更安全地交付軟件。Puppet還給開發(fā)人員提供了小型項目可以使用的 開源工具 。但是,如果你負(fù)責(zé)的是較大的基礎(chǔ)架構(gòu),就會發(fā)現(xiàn)Puppet Enterprise的 額外特性 是有價值的,比如:
實時報告
基于角色的訪問控制
節(jié)點(diǎn)管理
使用Puppet Enterprise,你可以管理多個團(tuán)隊和數(shù)千資源。它能自動理解基礎(chǔ)架構(gòu)里的關(guān)系。它處理依賴關(guān)系并且智能地處理故障。當(dāng)遇到一次失敗的配置時,它也會跳過所有依賴的配置。Puppet最好的一點(diǎn)是它有 5000多個模塊 ,可以和 很多流行的DevOps工具 集成。
8. Ansible
Ansible 是一個配置管理工具,和Puppet,Chef類似。用戶可以用它配置自己的基礎(chǔ)架構(gòu)并且自動化部署。和其他類似的DevOps工具相比,它的主要賣點(diǎn)是簡潔易用。Ansible遵循和Puppet一樣的基礎(chǔ)架構(gòu)即代碼(IAC)的理念。但是,它使用超級簡單的YAML語法。使用Ansible,用戶可以在YAML里定義任務(wù),而Puppet則有自己的聲明式語言。
無代理的架構(gòu)是另一個經(jīng)常被提及的Ansible的特性。因為后臺沒有運(yùn)行daemon或者代理,Ansible是安全并且輕量級的配置管理自動化的解決方案。和Puppet類似,Ansible也有 一些模塊 。
如果想要更好地理解Ansible在DevOps工作流里是怎么工作的,可以查看Red Hat Blod里的 這篇博文 。它介紹了在Jenkins流水線里,如何使用Ansible來預(yù)配環(huán)境以及部署應(yīng)用。
9. Nagios
Nagios 是最流行的免費(fèi)并開源的DevOps監(jiān)控工具。它可以監(jiān)控基礎(chǔ)架構(gòu)從而幫助用戶發(fā)現(xiàn)并解決問題。使用Nagios,用戶可以記錄事件,運(yùn)行中斷以及故障。用戶還可以通過Nagios的圖表和報告監(jiān)控趨勢。這樣,可以預(yù)測運(yùn)行中斷和錯誤,并且發(fā)現(xiàn)安全攻擊。
雖然基礎(chǔ)架構(gòu)監(jiān)控里有很多DevOps工具,但是Nagios因為其豐富的 插件生態(tài) 而脫穎而出。因為Nagios已經(jīng)發(fā)布很多年了(2002年發(fā)布),圍繞它的社區(qū)很大。除了插件,社區(qū)還貢獻(xiàn)了add-on,指導(dǎo)文章,翻譯等等有用的東西——都是免費(fèi)的。
Nagios提供了四中開源監(jiān)控解決方案:
Nagios Core
Nagios XI
Nagios Log Server
Nagios Fusion
Nagios Core是一個命令行工具,提供了所有基本功能。用戶還可以選擇 Nagios XI ,它提供了基于網(wǎng)頁的GUI以及監(jiān)控向?qū)С绦颉agios提供了 功能的比對 。
Nagios Log Server讓用戶可以搜索日志數(shù)據(jù),并且配置可能攻擊的報警。Nagios Fusion可以同時監(jiān)控多個網(wǎng)絡(luò)。
整體來說,Nagios給DevOps團(tuán)隊提供了基礎(chǔ)架構(gòu)監(jiān)控解決方案。但是,它需要一定的時間搭建,并且需要考慮和你的環(huán)境的兼容性。
10. Raygun
Raygun 是領(lǐng)先的錯誤監(jiān)控以及崩潰報告的平臺。 應(yīng)用程序性能監(jiān)控 (APM)是其最近的項目。Raygun的DevOps工具幫助用戶分析性能問題,并且定位到代碼的某一行,某個function或者API調(diào)用。APM工具和Raygun的錯誤管理工作流可以協(xié)同工作。比如,它自動定位最高優(yōu)先級的問題,并創(chuàng)建issue。
Raygun APM能夠幫助最大化其他DevOps的價值,因為你總是能收到問題通知。因為它自動將錯誤鏈接到源碼里,Raygun給整個團(tuán)隊提供統(tǒng)一的真理來源來定位錯誤和性能問題,將開發(fā)和運(yùn)維緊密聯(lián)系在一起。
哪些DevOps工具適合你的團(tuán)隊?
找到最佳的DevOps工具需要一些測試和經(jīng)驗。搭建以及配置開源軟件通常需要更多時間。大多數(shù)商業(yè)DevOps工具都有免費(fèi)試用版本,用戶可以測試并且評估。最終選擇哪些工具取決于團(tuán)隊的需求和目標(biāo)。