離線部署 Jenkins 填坑指南
本文目錄如下:

一、背景
在實(shí)際項(xiàng)目中,通過這些實(shí)踐,目前已經(jīng)穩(wěn)定運(yùn)行了兩個(gè)月,現(xiàn)在又有了一個(gè)新項(xiàng)目也是需要用 Jenkins 來實(shí)現(xiàn)自動(dòng)化部署,但新項(xiàng)目的部署環(huán)境是 Linux 離線環(huán)境,所以我需要在離線環(huán)境上再部署一遍。
因?yàn)椴渴?Jenkins 的機(jī)器上沒有網(wǎng)絡(luò),所以部署的過程中遇到了很多坑,本篇文章也是為了記錄期間遇到的坑,以及解決方案。
二、依賴項(xiàng)
部署后端項(xiàng)目時(shí)需要依賴 Java、Maven、Git,對(duì)應(yīng)的離線包版本如下表所示。
序號(hào) | 依賴項(xiàng) | 版本 |
1 | Linux 服務(wù)器 | 建議 ubuntu 20 以上 |
2 | Jenkins 離線 war 包 | 2.426.1(當(dāng)前最新版本) |
3 | Java 離線包,后端部署需要 | Java 11, Java 17 or Java 21 |
4 | Maven 離線安裝,后端部署需要 | Maven 3.8.8 |
5 | Git 離線包,拉取代碼 | 2.9.5(當(dāng)前最新版本) |
關(guān)于離線部署前端項(xiàng)目會(huì)放到下一講。
三、下載 Jenkins 安裝包
安裝包路徑:
https://get.jenkins.io/war-stable/選擇版本:2.426.1
圖片
下載完是一個(gè) war 包,后續(xù)用 Java 啟動(dòng)這個(gè) war 包即可。
圖片
四、安裝 Java
下載 Java 17 安裝包
圖片
創(chuàng)建目標(biāo)目錄:
sudo mkdir -p /usr/local/java復(fù)制安裝包到目標(biāo)目錄:
sudo cp /path/to/jdk-17_linux-x64_bin.tar.gz /usr/local/java解壓安裝包:
cd /usr/local/java
sudo tar -xvzf jdk-17_linux-x64_bin.tar.gz移除壓縮包:
sudo rm jdk-17_linux-x64_bin.tar.gz配置環(huán)境變量:
sudo vim /etc/profile
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
export JAVA_HOME=/usr/local/java
export PATH=$PATH:$JAVA_HOME/bin加載環(huán)境變量:
source /etc/profile檢查 Java 版本:
java -version
java 版本
五、啟動(dòng) Jenkins
啟動(dòng)方式分為兩種:
- 直接啟動(dòng)
- 后臺(tái)靜默啟動(dòng)
直接啟動(dòng) jenkins
執(zhí)行啟動(dòng)的命令:
java -jar jenkins.war --httpPort=8082后臺(tái)靜默啟動(dòng)
執(zhí)行啟動(dòng)的命令:
nohup java -jar jenkins.war --httpPort=8082 >nohup.out 2>&1 &打開 Jenkins 站點(diǎn)
打開 Jenkins 站點(diǎn) http://<你的服務(wù)器ip>:8082。
遇到異常,提示如下:
圖片
java.lang.RuntimeException: Fontconfig head is null, check your fonts or fonts configuration解決方案:
將安裝了 java8 的 fontconfig.bfc 文件拷貝到 jenkins 那臺(tái)服務(wù)器上的 java lib 目錄下
fontconfig.bfc 示例路徑:C:\Program Files\Java\jre1.8.0_191\lib\fontconfig.bfc
拷貝到 /usr/local/java/lib/ 目錄再次啟動(dòng),運(yùn)行成功。另外有一個(gè)提示無(wú)法訪問 jenkins 更新網(wǎng)站的錯(cuò)誤,可以忽略,因?yàn)樵摲?wù)器沒聯(lián)網(wǎng)所以訪問不到。
圖片
jenkins 運(yùn)行目錄
另外還需要從打印的日志找到 jenkins 的運(yùn)行目錄,后續(xù)會(huì)用到。
如下圖所示,在 /home/xxx/.jenkins 目錄。
jenkins 運(yùn)行目錄
該目錄下有一個(gè)非常重要的目錄:plugins,我們可以拷貝一些插件到這個(gè)目錄里面,這樣 jenkins 就可以啟動(dòng)這些插件了。
圖片
六、配置 maven
下載地址:
https://maven.apache.org/download.cgi解壓文件夾:
cd /usr/local
tar -zvxf /usr/local/maven/apache-maven-3.8.8-bin.tar.gz
mv apache-maven-3.8.8/* maven
sudo rm -rf apache-maven-3.8.8
sudo rm -rf /usr/local/maven/apache-maven-3.8.8-bin.tar.gz添加環(huán)境變量:
sudo vim /etc/profile配置信息:
export M2_HOME=/usr/local/maven
export MAVEN_HOME=/usr/local/maven
export PATH=${M2_HOME}/bin:${PATH}加載配置
source /etc/profile查看 maven 配置是否生效:
mvn -version
圖片
七、配置 Git
下載安裝包
網(wǎng)站路徑:https://mirrors.edge.kernel.org/pub/software/scm/git/拷貝到這個(gè)目錄下 /usr/local/git/,如果沒有 git 目錄則新建一個(gè)。
sudo mkdir -p /usr/local/git
圖片
解壓 git 安裝包
sudo tar -xvzf /usr/local/git/git-2.9.5.tar.gz -C /usr/local/git編譯 git
cd /usr/local/git
./configure --prefix=/usr/local/git
make && make install提示沒有 gcc 編譯器:
圖片
解決方案:離線安裝依賴包。
- 下載依賴的安裝包
下載地址:https://pkgs.org/search/?q=libnl-genl
- 安裝依賴的安裝包
dpkg -i xxx.deb再次編譯,提示編譯成功
圖片
圖片
添加 git 環(huán)境變量:
export PATH=$PATH:/usr/local/git/bin
source /etc/profile查看 git 版本:
git --version
八、安裝 Jenkins 插件
離線環(huán)境下,不能通過直接選擇插件安裝的方式,所以需要將插件的離線包導(dǎo)入到 plugins 目錄下。
- 方式一:在線下載插件離線包并導(dǎo)入到 Jenkins 后臺(tái)。
- 方式二:批量拷貝同版本 Jenkins 在線安裝的插件。
方式一:下載插件并導(dǎo)入
以下兩個(gè)站點(diǎn)都可以在線下載插件。
https://plugins.jenkins.io/
http://updates.jenkins-ci.org/download/plugins/
安裝 Git 插件
圖片
可能會(huì)提示依賴的插件不存在,如下所示:
- Plugin is missing: structs (308.v852b473a2b8c)
- Plugin is missing: workflow-scm-step (2.13)
- Plugin is missing: scm-api (595.vd5a_df5eb_0e39)
- Plugin is missing: mailer (408.vd726a_1130320)
- Plugin is missing: credentials (2.6.1)
- Plugin is missing: git-client (3.11.0)
- Plugin is missing: script-security (1131.v8b_b_5eda_c328e)
- Plugin is missing: workflow-step-api (622.vb_8e7c15b_c95a_)
- Plugin is missing: credentials-binding (1.27.1)
- Plugin is missing: ssh-credentials (1.19)因?yàn)橛行┎寮蕾嚻渌寮?,所以需要先將其他插件安裝,如果再安裝的過程中又遇到缺失其他的插件,都按這種方式處理。
方式二:批量拷貝已安裝的插件
先在有網(wǎng)的機(jī)器上部署相同的版本的 Jenkins,然后在線安裝所需插件,最后批量拷貝插件到離線的 Jenkins 插件目錄下。
插件所在的目錄一般在這里:
/home/<user>/.jenkins/plugins/拷貝之后,重啟 Jenkins 就會(huì)自動(dòng)安裝這些插件了。
九、配置全局工具
配置 Maven settings
在 Jenkins 后臺(tái)系統(tǒng)管理->全局工具配置中添加 Maven settings 配置,如下圖所示。
路徑為 Maven setting 的文件路徑:/usr/local/maven/conf/settings.xml。
圖片
配置 Maven 安裝
在 Jenkins 后臺(tái)系統(tǒng)管理->全局工具配置中添加 Maven 安裝配置,如下圖所示。
路徑為 Maven 的安裝路徑:/usr/local/maven/。
圖片
配置 Java JDK
在 Jenkins 后臺(tái)系統(tǒng)管理->全局工具配置中添加 Java 配置,如下圖所示:
路徑為 Java 的安裝路徑:/usr/local/java/。
JDK 路徑配置
配置 Git
在 Jenkins 后臺(tái)系統(tǒng)管理->全局工具配置中添加 Git 配置,如下圖所示:
路徑為 Java 的安裝路徑:/usr/bin/git。
圖片
十、問題
問題 1、pipeline 輸入框沒有顯示出來
F12 調(diào)試工具可以報(bào)錯(cuò)信息如下:
jenkins workflow-editor.js Ajax is not defined ReferenceError: Ajax is not defined原因
插件有問題。
解決方案
替換所有插件文件。安裝一個(gè)同樣版本的 jenkins,并在線下載插件,并刪除原 jenkins 的插件目錄,然后替換全部插件文件。
問題 2、bat 命令不識(shí)別
java.io.IOException: Batch scripts can only be run on Windows nodes原因
當(dāng)前 Jenkins 部署在 Linux 系統(tǒng)中,所以不能識(shí)別 bat 命令。因?yàn)?bat 命令是 windows 系統(tǒng)使用的命令,而 sh 命令才是 linux 系統(tǒng)使用的命令。
解決方案
將 bat 改為 sh。
問題 3、執(zhí)行 sudo 命令需要密碼
SSH: EXEC: STDOUT/STDERR from command [sudo docker service update --force job-executor] ...
SSH: EXEC: connected
sudo: no tty present and no askpass program specified原因
由于 jenkins 帳號(hào)并沒有開啟免密碼導(dǎo)致的。
解決方法
給jenkins添加不用密碼使用sudo的權(quán)限。
sudo vi /etc/sudoers在sudoers文件中加一行:
jenkins ALL=(ALL) NOPASSWD:ALL問題 4、RoleBasedAuthorizationStrategy 插件問題
報(bào)錯(cuò)信息
SEVERE jenkins.InitReactorRunner$1#onTaskFailed: Failed Loading global config
com.thoughtworks.xstream.mapper.CannotResolveClassException: com.michelin.cio.hudson.plugins.rolestrategy.RoleBasedAuthorizationStrategy原因
jenkins 插件安裝有問題導(dǎo)致無(wú)法啟動(dòng) jenkins
解決方案
修改 /home/xxx/.jenkins/config 文件
<authorizationStrategy class="hudson.security.FullControlOnceLoggedInAuthorizationStrategy">
<denyAnonymousReadAccess>true</denyAnonymousReadAccess>
</authorizationStrategy>問題 5、需要更新插件版本
部分插件由于缺少依賴無(wú)法加載。要恢復(fù)這些插件提供的功能,需要修復(fù)這些問題并重啟 Jenkins。
圖片
原因
缺少插件或版本不正確。
解決方案
將對(duì)應(yīng)的版本的插件 xxx.jpi 下載后,在后臺(tái)上傳,部署插件完成后,勾選重啟 jenkins 服務(wù)。
問題 6、Git 拉取代碼提示證書問題
報(bào)錯(cuò)信息:
server certificate verification failed. CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile:原因
缺少證書。
解決方案
跳過 Git 的證書驗(yàn)證。
git config --global http.sslVerify false問題 7、配置環(huán)境變量后,找不到 sudo 命令
報(bào)錯(cuò)信息:
Command 'sudo' is available in '/usr/bin/sudo'原因
環(huán)境變量配置有問題,找不到
解決方案
使用以下命令重新打開 /etc/profile 文件
/usr/bin/sudo /usr/bin/vim /etc/profile把以下環(huán)境變量配置到 profile 中的其他環(huán)境變量之前
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
圖片
問題 8、Jenkins 時(shí)區(qū)問題相差 8 小時(shí)
解決方案
- 進(jìn)入 Jenkins 的系統(tǒng)管理頁(yè)面。
- 點(diǎn)擊“腳本命令行”。
- 執(zhí)行以下命令以設(shè)置時(shí)區(qū)為北京時(shí)間:
System.setProperty('org.apache.commons.jelly.tags.fmt.timeZone', 'Asia/Shanghai')- 確保時(shí)區(qū)設(shè)置正確以便任務(wù)構(gòu)建和定時(shí)構(gòu)建按照北京時(shí)間觸發(fā)。
十一、總結(jié)
本篇講解了在離線環(huán)境下如何部署 Jenkins、Jenkins 插件、Maven、Java、Git 工具。
在部署的過程中遇到了很多坑,遇到一個(gè)解決一個(gè),希望大家在以后遇到類似問題時(shí),能根據(jù)本文檔縮短排查問題的時(shí)間。


























