1.2 Jenkins系统安装

Jenkins是基于Java语言开发的持续集成系统,可以运行在任何安装了Java运行环境的计算机上。本节,笔者将为读者逐步演示Jenkins服务端(Server)和代理端(Agent)的安装部署。

1.2.1 准备工作

Jenkins采用分布式架构,由服务端节点和代理端节点组成。服务端主要负责流水线作业的调度,代理端实际运行流水线作业。Jenkins架构图如图1-6所示。

图1-6 Jenkins架构图

提示:

为了保障Jenkins平台的稳定性,笔者建议不要在生产环境的Jenkins服务端节点上运行流水线作业——当运行大量任务时,可能会使Jenkins节点崩溃,这会影响节点的性能。

1.操作系统

Jenkins是跨平台(Windows/Linux/macOS)的,部署方式可以选择通过本机系统包、Docker、Kubernetes等。笔者实验环境是Linux CentOS 8操作系统。以下是系统和内核版本的信息。

[root@jenkins-service ~]#cat /etc/redhat-release
CentOS Stream release 8
[root@jenkins-service ~]#uname -r
4.18.0-373.el8.x86_64

2.安装JDK

Jenkins是使用Java语言开发的,运行时需要依赖JDK环境。自Jenkins LTS(长期支持版本)2.346.x之后,安装部署时最低版本要求是JDK11(参考更新说明见https://www.jenkins.io/doc/upgrade-guide/2.346/)。

JDK11的安装过程可以参考以下代码。

#下载JDK11压缩包
[root@jenkins-service ~]#wget https://github.com/adoptium/temurin10-
binaries/releases/download/jdk-11.0.16.1%2B1/OpenJDK11U-jdk_x64_linux_
hotspot_11.0.16.1_1.tar.gz

#解压
[root@jenkins-service ~]#tar zxf OpenJDK11U-jdk_x64_linux_hotspot_
11.0.16.1_1.tar.gz -C /usr/local
[root@jenkins-service ~]# cd /usr/local/jdk-11.0.16.1+1/
[root@jenkins-service jdk-11.0.16.1+1]# ls
bin  conf  include  jmods  legal  lib  man  NOTICE  release

#设置环境变量
[root@jenkins-service ~]#vim /etc/profile
export JAVA_HOME=/usr/local/jdk-11.0.16.1+1
export PATH=$JAVA_HOME/bin:$PATH
[root@jenkins-service ~]#source /etc/profile

#配置软链接
[root@jenkins-service jdk-11.0.16.1+1]# ln -sf /usr/local/jdk-11.0.16.1+1/
bin/java /usr/bin/

#验证版本信息
[root@jenkins-service jdk-11.0.16.1+1]# /usr/bin/java  -version
openjdk version "11.0.16.1" 2021-07-12
OpenJDK Runtime Environment Temurin-11.0.16.1+1 (build 11.0.16.1+1)
OpenJDK 63-Bit Server VM Temurin-11.0.16.1+1 (build 11.0.16.1+1, mixed mode)

1.2.2 安装Jenkins

在CentOS中需要下载系统rpm包来安装Jenkins服务端。笔者本次安装采用的是2.346.2-1.1版本,建议使用国内源下载对应的rpm包,如清华源(https://mirrors.tuna.tsinghua.edu.cn/jenkins/)。具体的安装步骤及参考代码如下。

1.下载系统包

下载系统包的命令如下。

[root@jenkins-service~]#wget https://mirrors.tuna.tsinghua.edu.cn/
jenkins/redhat-stable/jenkins-2.346.3-1.1.noarch.rpm

2.安装系统包

安装系统包的命令如下(见图1-7)。

[root@jenkins-service ~]#rpm -ivh jenkins-2.346.3-1.1.noarch.rpm

图1-7 安装Jenkins服务

3.启动服务

下面启动Jenkins服务并检查服务的状态,如图1-8所示。

图1-8 启动Jenkins服务

4.设置服务开机自启

设置Jenkins服务开机自启,如图1-9所示。

图1-9 设置Jenkins服务开机自启

当我们完成上面的操作后,可以通过ps aux命令查看服务进程。如下面代码所示,通过进程的启动参数可以得知Jenkins默认的HTTP监听端口是8080。

#查看服务进程
[root@jenkins-service ~]#ps aux | grep java | grep jenkins
jenkins     3779 29.5  9.1 14278716 2984916 ?    Ssl  21:12   0:25 /usr/bin/
java -Djava.awt.headless=true -jar /usr/share/java/jenkins.war --webroot=
/var/cache/jenkins/war --httpPort=8080

1.2.3 初始化

Jenkins服务端安装好之后还有一个初始化的过程,通过浏览器访问http://<service_ip>: 8080即可进入初始化页面。

初始化的步骤如下。

1.解锁系统

为了安全地安装Jenkins,会将解锁需要的密码存储到Jenkins启动日志或者/var/lib/ jenkins/secrets/initialAdminPassword文件中。读者可任选其中一种方式,将密码粘贴到输入框,单击“继续”按钮,如图1-10所示。

图1-10 Jenkins解锁

2.安装插件

Jenkins的功能扩展都来自于插件。Jenkins插件资源丰富,为了集成一些工具,我们不得不安装很多插件,但是在生产环境中,笔者不建议大家安装太多无用的插件,因为插件增多会影响Jenkins的启动速度,插件安装方式如图1-11所示。

图1-11 Jenkins插件安装方式

此处选择“选择插件来安装”进入插件的选择页面,如图1-12所示。可以看到Jenkins默认选择了一些插件,这里我们单击“无”取消默认选择的插件,然后根据需求安装本地化语言插件。

图1-12 选择Jenkins插件

单击“安装”按钮即可进入插件安装进度页面,在该页面可以看到已选择插件的安装进度和日志信息。

提示:

这个步骤很容易出现插件安装停顿的问题,多数情况是因为网络问题导致的,因此要保持网络畅通。

3.创建用户

插件安装完成后,会自动跳转到管理员用户创建页面,填写用户名、密码等信息,单击“保存并完成”按钮,如图1-13所示。

图1-13 创建管理员用户

4.配置实例

当前笔者的环境机器IP是192.168.1.200,端口号使用的是Jenkins默认设置的8080。如果读者的端口或者IP地址发生了变化,记得更新这里的设置,如图1-14所示。

5.完成初始化

如果进入如图1-15所示的页面,意味着安装和初始化Jenkins服务端完成。

图1-14 Jenkins实例配置

图1-15 Jenkins安装完成

第一次安装部署完成后,如果Jenkins管理页面显示的是英文,重启后会显示中文,如图1-16所示。

图1-16 Jenkins首页

1.2.4 安装Agent节点

Jenkins的代理端主要用于运行Jenkins服务端所调度的流水线作业。它的部署方式与服务端一样是跨平台的。为了减少实验环境的资源,笔者将Jenkins服务端和代理端部署在同一台机器中。注意:实际生产环境要采用高性能的服务器进行独立部署。

1.配置节点

单击左侧“系统管理”进入“管理Jenkins”页面,在页面中可以看到“节点管理”选项,如图1-17所示。

图1-17 Jenkins节点管理

进入节点管理页面,可以看到已经在线的服务端master节点。单击左侧菜单中的“新建节点”,如图1-18所示。

图1-18 Jenkins新建节点

进入新建节点页面后,填写要创建的节点名称和Type(节点类型)。因为笔者将Jenkins Agent节点部署到了一台固定的机器上,所以Type选择固定节点,如图1-19所示。

图1-19 填写Jenkins节点信息

单击Create按钮创建节点并进入节点的详细配置页,如图1-20所示。

各个配置项的说明如下。

 名字:填写节点的名称。

 描述:填写节点的描述信息。

 Number of executors:执行器的数量,默认每一个Jenkins作业会分配一个执行器。

 远程工作目录:Agent节点的工作目录。

 标签:可以对节点进行分组,便于流水线调度。

 用法:哪些作业可以使用这些节点,选择“只允许运行绑定到这台机器的Job”或者“经常使用该节点”即可运行任意作业。

图1-20 Jenkins节点详细配置

在Jenkins的生产环境中,常用的启动方式为SSH和JNLP。JNLP对应中文为“通过Java Web启动代理”。这里笔者选择“通过Java Web启动代理”,如图1-21所示。

图1-21 Jenkins节点启动方式

提示:

如果遇到“Either WebSocket mode is selected, or the TCP port for inbound agents must be enabled”错误提示,是因为在Jenkins新版本中,默认禁用了TCP端口。我们需要导航到“系统管理>管理Jenkins >安全>全局安全”配置开启TCP端口,如图1-22所示。

图1-22 Jenkins Server与Agent通信端口配置

这里笔者默认配置的是50000端口,此端口作为后续Agent节点启动时与Server节点通信使用。

填写好上面的配置并保存。系统会自动进入节点页面,可以看到刚刚增加的节点配置成功(此时节点添加成功但是还不能运行作业,需要启动代理程序),如图1-23所示。

图1-23 Jenkins节点管理

2.启动节点

以“Java Web”方式设置的代理节点,需要下载启动程序。参考图1-23单击节点进入节点信息页面,获取agent.jar的下载链接。启动节点的步骤如下。

1)创建Agent目录

创建一个目录用于存储Jenkins Agent的安装程序,命令如下。

#创建Agent目录
[root@ jenkins-service ~]#mkdir jenkinsagent
[root@ jenkins-service ~]#cd jenkinsagent/

2)下载Agent启动程序

Agent启动程序是一个Java语言开发的jar包。下载的命令如下。

#下载代理程序
[root@ jenkins-service jenkinsagent]#wget http://192.168.1.200:8080/
jnlpJars/agent.jar
--2021-9-10 22:27:30--  http://192.168.1.200:8080/jnlpJars/agent.jar

3)启动Agent程序

使用Java命令启动Agent程序,如图1-24所示。

图1-24 启动Jenkins Agent程序

提示:

根据笔者的经验,此步骤出现问题的概率很高。大部分情况都是网络问题导致的,例如检查Agent节点与Jenkins Server节点的50000端口和8080端口的连通性是否正常。

当出现“Connected”关键字时查看节点管理页面,可以看到该Agent已经连接成功。刷新节点页面,如图1-25所示。

图1-25 Jenkins节点状态

提示:

当前节点启动成功,但是Jenkins Agent程序并未后台运行。也就是说,终端关闭后程序就停止了,需要进一步优化。笔者习惯将启动命令写到脚本中,用nohup的方式启动程序可以参考以下代码。

#!/bin/bash

nohup java -jar agent.jar -jnlpUrl http://192.168.1.200:8080/computer/
build01/jenkins-agent.jnlp -secret @secret-file -workDir "/opt/
jenkinsagent" &

至此,我们完成了Jenkins Agent节点的安装,我们的基础环境准备好了。