Jenkins中至多构建项目的类型有很多,常用的有以下三种:
- 自由风格软件项目(FreeStyle Project)
- Maven项目(Maven Project)
- 流水线项目(Pipeline Project)
今天我们要说的也是这三种类型,实际上每种类型的构建都可以完成一样的构建过程与结果,只是在操作方式、灵活度等方面有所区别,在实际开发中可以根据自己的需求和习惯来选择。从灵活度上来说,流水线类型是最高的。
1. 自由风格项目构建
其实在之前的几篇文章中,我们的测试构建项目都是使用自由风格完成的。其整个项目的集成过程:拉取代码->编译->打包->部署,本篇文章将不再举例说明。
2. Maven项目构建
(1)安装Maven Integration
插件
(2)创建Maven项目
(3)配置项目(源码管理和自由风格项目是一样的,只是构建部分存在差异)
(4)开始构建,并输出构建结果
3. Pipeline流水线项目构建
3.1 Pipeline简介
简单来说,Pipeline就是一套运行在 Jenkins 上的工作流框架,将原来独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排和可视化的工作。
Pipeline支持两种语法:声明式(Declarative)和脚本式(Scripted Pipeline)语法。
3.2 安装Pipeline插件
3.3 声明式项目构建
(1)创建项目
(2)流水线->选择HelloWorld模块,生成内容如下:
- stages:代表整个流水线的所有执行阶段,通常stages只有1个,里面包含多个stage。
- stage:代表流水线中的某个阶段,可能出现n个。一般分为拉取代码、编译构建、部署等阶段。
- steps:代表一个阶段内需要执行的逻辑。steps里面是shell脚本,git拉取代码、ssh远程发布等任意内容。
这里,我们编写一个简单声明式的Pipeline,来感受一下整个构建过程:
pipeline {
agent any
stages {
stage('拉取代码') {
steps {
echo '拉取代码'
}
}
stage('编译构建') {
steps {
echo '编译构建'
}
}
stage('项目部署') {
steps {
echo '项目部署'
}
}
}
}
(3)开始构建,并输出构建结果
3.4 脚本式项目构建
(1)创建项目
(2)流水线->选择Scripted Pipeline
- Node :节点,一个 Node 就是一个 Jenkins 节点,Master 或者 Agent,是执行 Step 的具体运行环境。
- Stage :阶段,一个 Pipeline 可以划分为若干个 Stage,每个 Stage 代表一组操作,比如:Build、Test、Deploy,Stage 是一个逻辑分组的概念。
- Step :步骤,Step 是最基本的操作单元,可以是打印一句话,也可以是构建一个 Docker 镜像,由各类 Jenkins 插件提供,比如命令:sh ‘make’,就相当于我们平时 shell 终端中执行 make 命令一样。
编写一个简单的脚本式Pipeline:
node {
def mvnHome
stage('Preparation') {
echo '拉取代码'
}
stage('Build') {
echo '编译构建'
}
stage('Results') {
echo '项目部署'
}
}
(3)开始构建,并输出构建结果
4. Demo项目的流水线构建
介绍完三种常见的构建类型,可以知道的是流水线类型是最复杂的,但同时它也是最灵活的。实际项目中,流水线类型也是用的最多的一种。在上面我们也只是使用echo
来模拟了各个阶段的构建过程,现在我们使用一个较为真实的Demo项目来看一下各个阶段都是怎么写流水线构建脚本的。
4.1 拉取代码
pipeline {
agent any
stages {
stage('拉取代码') {
steps {
checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: '8a039ab1-9d39-49a2-888b-03dbe9ee60e1', url: 'http://192.168.1.19:82/test-group/demo.git']]])
}
}
}
}
4.2 编译打包
pipeline {
agent any
stages {
stage('拉取代码') {
steps {
checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: '8a039ab1-9d39-49a2-888b-03dbe9ee60e1', url: 'http://192.168.1.19:82/test-group/demo.git']]])
}
}
stage('编译构建') {
steps {
sh label: '', script: 'mvn clean package'
}
}
}
}
4.3 开始构建
5. Pipeline Script from SCM
刚才我们都是直接在Jenkins的UI界面编写Pipeline代码,这样不方便脚本维护,建议把Pipeline脚本放在项目中(一起进行版本控制)。
(1)在项目根目录建立Jenkinsfile文件,把内容复制到该文件中,然后提交到Gitlab。
(2)在项目中引用该文件,然后开始构建,构建结果当然也是成功的。