Jenkins敏捷開發 自動化構建工具

一、序言

Jenkins 是一款自動化構建工具,能夠基於 Maven 構建後端 Java 項目,也能夠基於 nodejs 構建前端 vue 項目,並且有可視化 web 介面。

所謂自動化構建是按照一定的策略執行打包腳本,相對於普通腳本構建,Jenkins 有如下優勢:

  • 構建隊列中能夠同時構建多個項目,包含前端和後端項目;
  • 定時構建;
  • 程式碼倉庫觸發構建(普通腳本無法實現);

Jenkins 體現一種項目管理思維:開發人員的貼心助理,集中精力專註於業務開發;儘早的實現程式碼集成(包含前後端)以便儘早發現問題;構建環境與開發環境隔離,為向生產環境遷移做好充足的準備。

構建過程全程自動化進行,無人工參與,配合 Docker 容易實現高效的項目部署與遷移。

二、安裝與使用

Jenkins 是一個工具,既然是一個工具,便有相應的替代方案,因此不需要花工作的時間琢磨這個工具是如何工作的,將精力放在如何利用 Jenkins 提高敏捷開發效率上更有意義。

實踐過程中,將項目的腳本化構建用 shell 編寫成命令腳本,並附加在項目中,即使不使用 Jenkins,通過執行 shell 腳本也能夠實現項目的自動化構建。這麼做主要有如下考慮:

  • 增強拓展性

即使沒有 Jenkins,項目也能完成構建,增加構建的拓展性

  • 減少對 Jenkins 的依賴

讓 Jenkins 承擔實踐調度的角色,具體構建過程由標準化的腳本來完成。

既然 shell 腳本能夠完成自動化構建,那麼還需要用到 Jenkins 嗎,是否衝突?答案是不衝突。shell 腳本配合 Jenkins 使用有兩大方面優勢:

  • 使用 shell 腳本必須登錄目標伺服器,擁有相應的許可權後,方能執行 shell 腳本,Jenkins 能夠實現在不登錄目標伺服器的基礎上,使用一對帳號和密碼,管理可視化的 Web 操作介面觸發構建事件。
  • 按需構建,開發者在提交完程式碼後,向 Jenkins 伺服器發送一個訊號,便可觸發構建。

(一)安裝

使用傳送門快捷安裝,啟動後使用安裝推薦插件,內置中國插件源,安裝速度較快。

1、查看初始密碼
cat ~/.jenkins/secrets/initialAdminPassword
2、修改默認工作空間

默認工作空間路徑為~/.jnkins,運行 Jenkins 程式的用戶空間下,構建完成後的項目,如果要放在第三方容器中運行時,有可能會出現找不到路徑的情況,修改默認工作空間或者給予資源目錄可執行許可權都能解決此問題。

安裝完成之後,暫時啟動程式,先確認是否需要修改Jenkins_HOME變數,後續初始化以及插件的安裝與此路徑有關。此變數修改方式有多種,顆粒度較大的是配置在 PATH 環境變數中,顆粒度較小的是配置在運行 Jenkins 項目的容器中。

修改 Tomcat 的配置文件 context.xml,增加一行配置

<!-- 創建一個jenkins,並將其用戶空間設置為JENKINS_HOME -->
<Environment name="JENKINS_HOME" value="/home/jenkins" type=java.lang.String/>

注意JENKINS_HOME默認值為啟動進程用戶對應的用戶空間,在啟動前修改後即變成新的路徑。

(二)使用

如果在配置遠程 APiToken 觸發不生效,請閱讀免密登錄章節。

1、構建配置

用腳本的方式構建 Jenkins 項目配置非常簡單,儘管內置了很多花里胡哨的配置,這裡用不到,不需要關心。

image-20210406125139052

只需要在構建中添加執行 shell 腳本命令即可。附錄中列舉的環境配置統一在宿主機上完成,不在 Jenkins 服務內部配置,使用默認值即可。

2、添加項目

在宿主機上將待構建項目的源程式碼克隆到本地,執行 shell 腳本完成手動構建。在 Jenkins 管理工作台新建一個同名的空項目,將克隆的源程式碼整體複製到 Jenkins 的工作空間下,默認位置為/root/.jenkins/workspace,委託給 Jenkins 代為自動管理該項目。

(三)免密登錄

使用 URL 觸發構建事件,需要配置免密登錄,即在不需要輸入用戶名和密碼的情況下,通過遠程調用 shell 腳本觸發構建事件,此 shell 腳本本質上是 GET 的方式請求某個指定的路徑。操作過程如下:

(1)安裝插件

安裝Build Authorization Token Root Plugin插件,如果已經存在,則忽略此步驟。此插件的作用是給當前登錄的用戶生成 Token,方便後續認證使用,一個用戶可以配置多個 token。

(2)項目配置

在指定的項目中添加 token 配置,項目可以復用一個 token 或者每個項目單獨設置一個 token,依據需要選擇。只有添加此配置之後,使用 token 觸發方能生效。

image-20210406181556605

(3)客戶端使用

編寫腳本,將腳本分發給開發者,自動化構建便可以愉快的開始了。使用curl多參數時,&符號需要轉義。

curl {Jenkins URL}/buildByToken/build?job={項目名}\&token={token}

至此,CI/CD敏捷開發配置完畢。

三、觸發策略

構建事件可以按照不同的策略來定義,定時屬於被動觸發;URL 和鉤子程式屬於主動觸發。

(一)定時觸發

定時觸發有多種實現方案,使用 CentOS 伺服器內置的定時調度器是較為輕量的解決方式,實現原理是在指定的時間節點運行 shell 腳本,其中 shell 腳本便是項目構建的載體。如果單純希望定時構建項目,推薦使用此種解決方式,Jenkins 略顯笨重。

(二)URL 觸發

用腳本模擬或者在瀏覽器訪問 URL 觸發構建事件。此種方式是開發中用的比較多的方式,按需構建的代表。軟體開發者在提交完程式碼後,主動觸發構建事件,這種方式構建效率較高。

Build Triggers

構建觸發器是指 Jenkins 收到某一訊號之後,立即開始構建指定的任務。

勾選【Trigger builds remotely】並設置【Authentication Token】

# 【服務前綴】/job/【任務名】/build?token=【token】
JENKINS_URL/job/job-vue/build?token=TOKEN_NAME

通過使用 curl 腳本即可觸發構建訊號。

(三)鉤子觸發

在程式碼倉庫完成鉤子程式配置,並且允許程式碼倉庫伺服器訪問 Jenkins 伺服器,鉤子程式會在開發者提交程式碼時觸發構建事件。

鉤子觸發看上去比較美,實際操作中有一定的前置條件:一是項目的構建時間不能過長;二是提交程式碼不能過於頻繁。

附錄、工具使用

1、語言設置

在【系統管理】>【插件管理】中添加【locale】插件。在【系統管理】>【全局配置】中 locale 欄目下添加【en_US】,並勾選對所有用戶生效選項。

建議統一使用英文介面(可以修改為中文),在中英文混合下操作比較彆扭。

2、構建環境清單
序號 環境名 作用及要求 參考資料
1 Java Java 程式基礎運行環境,使用 jdk 不能使用 jre(需要編譯 Java 源碼)
2 maven 構建 Java 項目,為提高構建速度需要配置中國倉庫源 Maven 使用手冊
3 NodeJS 構建前端項目
4 git 拉取遠程倉庫程式碼
5 ssh 免密登錄 授權拉取遠程倉庫程式碼;授權登錄遠程伺服器(構建完成後部署) SSH 使用手冊
3、環境配置

1、Maven Configuration

配置項 配置內容
Default settings provider /usr/local/maven/conf/settings.xml
Default global settings provider /usr/local/maven/conf/settings.xml

2、JDK

配置項 配置內容
JAVA_HOME /usr/local/java

3、Git

配置項 配置內容
Path to Git executable /usr/local/git/bin/git

4、Maven

配置項 配置內容
MAVEN_HOME /usr/local/maven

5、NodeJS

配置項 配置內容
Installation directory /usr/local/nodejs/bin
4、任務配置

1、Source Code Management

源程式碼管理是 Jenkins 工作的前提,即能夠獲取到任務源程式碼,它是後續程式碼自動構建的前提。

源程式碼託管在 GitHub,並且是私有倉庫,Jenkins 正確訪問 git 倉庫需要進行授權。

# 基於http用戶名和密碼授權
//gitee.com/decsa/ucode-cms-vue.git
# 基於公鑰和私鑰匙授權
[email protected]:decsa/ucode-cms-vue.git

為了提高工作效率,促進團隊協作,這裡選用 ssh 認證。

ssh-keygen -t rsa -C "[email protected]"

將文件【~/.ssh/id_rsa.pub】內字元串拷貝至 GitHub 設置中,配置後即可免密拉取 GitHub 私有倉庫程式碼。

更多內容請查看 SSH 使用手冊

2、Build Triggers

構建觸發器是指 Jenkins 收到某一訊號之後,立即開始構建指定的任務。

勾選【Trigger builds remotely】並設置【Authentication Token】

# 【服務前綴】/job/【任務名】/build?token=【token】
JENKINS_URL/job/ruoyi-vue/build?token=TOKEN_NAME

通過在任一登陸的伺服器的瀏覽器或者使用 curl 腳本即可出發任務的立即構建。

3、Build

後端項目通常使用 Maven 來構建,在下拉框中選擇【Invoke top-level Maven targets】,然後在 Goals 欄目中配置如下命令

clean install

經過此步驟,能夠在工作空間找到構建後的項目發布包。

4、Post-build Actions

在任務構建完成之後出發此操作。通常使用 Docker 將項目發布包構建成鏡像,然後發布到鏡像倉庫中。可執行的鏡像發布到鏡像倉庫之後,有兩種比較常用的後續方案與應用伺服器交互。

Jenkins 通過授權認證,登陸到目標應用伺服器,將對應的鏡像拉下來,然後使用腳本啟動。

通過使用 k8s 容器服務,自動化管理任務鏡像發布工作。

原文地址