《Jenkins 2.x實踐指南》讀書筆記-Jenkins 2.x簡介和pipeline示例

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)的語法。

  1. pipeline插件從2.5版本開始,才同時支持兩種格式的語法;
  2. 推薦主要使用聲明式語法,腳本式語法作爲輔助;

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)

實踐

  1. 進入Manage Jenkins→Global Tool Configuration->Maven頁添加mvn-3.5.4

在這裏插入圖片描述

  1. 進入Manage Jenkins→Global Tool Configuration→JDK頁添加jdk-8u172

在這裏插入圖片描述

注意這裏需要oracle帳戶驗證。

  1. 添加pipeline項目
    在這裏插入圖片描述

  2. 構建
    [外鏈圖片轉存失敗,源站可能有防盜鏈機制,建議將圖片保存下來直接上傳(img-j9kDMApF-1571912834590)在這裏插入圖片描述

因爲jenkins-slave是整合kubernetes的,因此每次構建都會安裝tools,如上圖可以看出,maven安裝包需要從官方下載,這對效率影響非常大。
若想優化可以考慮jenkins-slave鏡像中直接整合maven,而不是使用jenkins tools;還可以使用docker-in-docker配合maven鏡像。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章