什么是流水线
流水线比较好理解,类比于现实生活中的生产流水线,每个流程只做一件事,通过传送带把这些流程连接在一起,一个流程完成后的结果交由后续流程继续操作。
Jenkins的流水线也是这样工作的,最简单的认知是它可以把若干可通用的Shell脚本像胶水一样连接起来,虽然这个比喻比较形象,但这只是流水线的冰山一角。
在Jenkins升级2.x版本之前,流水线只有一种脚本式流水线(Script Pipeline),当升级2.x版本后,新增了声明式流水线(Declarative Pipeline)
无论是哪种流水线,都需要为流水线定义流水线脚本,称之为Jenkinsfile ,使用Groovy语法写成
脚本式流水线
在说明声明式流水线前,有必要了解一下脚本式流水线的基本概念,这样有利于我们知道声明式流水线的好处与脚本式流水线的限制
在脚本化流水线语法中, 一个或多个 node 块在整个流水线中执行核心工作。
虽然这不是脚本化流水线语法的强制性要求, 但它限制了你的流水线的在node块内的只能做两件事:
Jenkinsfile (Scripted Pipeline)
node { //需要有一个或多个node节点表示一系列操作
stage('Build') { //每个stage表示一个步骤
// Build步骤内容
}
stage('Test') {
// Test步骤内容
}
stage('Deploy') {
// Deploy步骤内容
}
}
声明式流水线的基本语法类似于脚本式流水线,但是其功能更加强大
声明式流水线最外层Jenkinsfile脚本节点是pipeline
声明式和脚本化的流水线从根本上是不同的。 声明式流水线的是 Jenkins 流水线更近的特性:
Jenkinsfile (Declarative Pipeline)
pipeline { // pipeline是声明式流水线的一种特定语法,在块内定义了整个流水线的所有内容
agent any // agent是声明式流水线的一种特定语法,它指示 Jenkins 为整个流水线分配一个执行器 (在节点上)和工作区,等效于脚本式流水线node块
stages { // 所有流程(状态)的外层块,仅有一个
stage('Build') { //每个stage为一流程,与脚本式基本一致,每个stage可以定义名称
steps { //步骤块,内部包含具体操作
sh 'make' // sh操作,其引号间的文字会当成shell直接执行
}
}
stage('Test'){
steps {
sh 'make check'
junit 'reports/**/*.xml' //junit使用匹配的定义测试xml进行单元测试
}
}
stage('Deploy') {
steps {
sh 'make publish'
}
}
}
}
使用jenkins的Blue Ocean插件运行构建:
Jenkinsfiles文件: