文章目錄
1. Jenkins 2.x簡介
1.1 pipeline是什麼
從某種抽象層次上講,部署流水線(Deployment pipeline)是指從軟件版本控制庫到用戶手中這一過程的自動化表現形式。——《持續交付——發佈可靠軟件的系統方法》(下稱《持續交付》)
按《持續交付》中的定義,Jenkins本來就支持pipeline(通常會把部署流水線簡稱爲pipeline,本書會交替使用這兩個術語),只是一開始不叫pipeline,而叫任務。
Jenkins 1.x只能通過界面手動操作來“描述”部署流水線。Jenkins 2.x終於支持pipeline as code了,可以通過“代碼”來描述部署流水線。
使用“代碼”而不是UI的意義在於:
- 更好地版本化:將pipeline提交到軟件版本庫中進行版本控制。
- 更好地協作:pipeline的每次修改對所有人都是可見的。除此之外,還可以對pipeline進行代碼審查。
- 更好的重用性:手動操作沒法重用,但是代碼可以重用。
本書全面擁抱pipeline as code,放棄依賴手動操作的自由風格的項目(FreeStyle project)。
1.2 Jenkinsfile又是什麼
Jenkinsfile就是一個文本文件,也就是部署流水線概念在Jenkins中的表現形式。像Dockerfile之於Docker。所有部署流水線的邏輯都寫在Jenkinsfile中。
1.3 pipeline語法的選擇
Jenkins pipeline有2種語法:腳本式(Scripted)語法和聲明式(Declar-ative)語法。
腳本式語法使用Groovy語言,其語法靈活、可擴展,但是也意味着更復雜。再者,Groovy語言的學習成本對於(不使用Groovy的)開發團隊來說通常是不必要的。所以纔有了聲明式語法,一種提供更簡單、更結構化(more opinionated)的語法。
- pipeline插件從2.5版本開始,才同時支持兩種格式的語法;
- 推薦主要使用聲明式語法,腳本式語法作爲輔助;
1.4 pipeline版本控制化
爲了便於維護和協作,使用版本倉庫對pipeline進行版本控制是生產使用過程中的最優選擇。
本人實踐過程中也是推薦書中提到的使用Git作爲版本控制倉庫,使用Jenkins ssh私鑰作爲憑證。
2. 利用github倉庫pipeline進行構建
以下爲本實驗地址:
https://github.com/ygqygq2/jenkins2_learning_install_tools
目的
使用jenkins拉取git倉庫內pipeline構建maven項目,達到了解pipeline基本用法。
環境
- github倉庫
- jenkins(已整合kubernetes)
實踐
- 進入Manage Jenkins→Global Tool Configuration->Maven頁添加
mvn-3.5.4
- 進入Manage Jenkins→Global Tool Configuration→JDK頁添加
jdk-8u172
注意這裏需要oracle帳戶驗證。
-
添加pipeline項目
-
構建
[外鏈圖片轉存失敗,源站可能有防盜鏈機制,建議將圖片保存下來直接上傳(img-j9kDMApF-1571912834590)
因爲jenkins-slave是整合kubernetes的,因此每次構建都會安裝tools,如上圖可以看出,maven安裝包需要從官方下載,這對效率影響非常大。
若想優化可以考慮jenkins-slave鏡像中直接整合maven,而不是使用jenkins tools;還可以使用docker-in-docker配合maven鏡像。