当前位置 : 主页 > 操作系统 > centos >

流水线pipeline招式之声明式(后篇)

来源:互联网 收集:自由互联 发布时间:2022-06-20
流水线pipeline招式之声明式(前篇)流水线pipeline招式之声明式(中篇) 大家好,今天是pipeline声明式的最后一篇。如果之前的内容还没有看,可以点击上方的的连接。那么废话不多说,

流水线pipeline招式之声明式(前篇)流水线pipeline招式之声明式(中篇)


大家好,今天是pipeline声明式的最后一篇。如果之前的内容还没有看,可以点击上方的的连接。那么废话不多说,开始今天的内容。

when条件判断

when 指令允许流水线根据给定的条件决定是否应该执行阶段。 when 指令必须包含至少一个条件。比如,我们想根据环境去判断执行不同的构建,那么我们可以下成如下样子

stage("test"){ when { branch 'test' } steps{ echo "deploy test!" } } stage("prod"){ when { branch 'prod' } steps{ echo "deploy prod!" } }

那么when都支持哪些条件的判断呢,我们下面来一一介绍:

branch,当正在构建的分支与模式给定的分支匹配时,执行这个阶段,也就是上面我们说的,通过分支去判断。这只适用于多分支流水线例如:

when { branch 'master' }

environment,当指定的环境变量是给定的值时,执行这个步骤,例如:

when { environment name: 'DEPLOY_TO', value: 'production' }

expression, 当指定的Groovy表达式评估为true时,执行这个阶段, 例如:

when { expression { return params.DEBUG_BUILD } }

这里要注意,当表达式返回的是字符串时,他必须转换为布尔值或者null,否则所有的字符串都被当做true处理。

not,当嵌套条件是错误时,执行这个阶段,必须包含一个条件,例如:

when { not { branch 'master' } }

allOf,当所有的嵌套条件都正确时,执行这个阶段,必须包含至少一个条件,例如:

when { allOf { branch 'master'; environment name: 'DEPLOY_TO', value: 'production' } }

anyOf,当至少有一个嵌套条件为真时,执行这个阶段,必须包含至少一个条件,例如:

when { anyOf { branch 'master'; branch 'staging' } }

equals,如果期望值和给定的值相同,则执行

when { equals expected: 2, actual: currentBuild.number }

buildingTag,如果pipeline所执行的代码被打了tag,则执行。

whne { buildingTag() }

tag,如果pipeline所执行的代码被打了tag,并且tag名符合规则,才执行。如果tag值为空,可以写成tag(),这个效果和buildingTag()一样,不论tag名称为什么,都执行。那么tag有几种匹配的方式呢?

  • EQUALS: 简单的文本比较 when { tag pattern: "release-3.1", comparator: "EQUALS" }
  • GLOB (默认值): Ant风格的路径表达式。由于是默认的使用的时候可以忽略
when { tag pattern: "release-*" }

或者写成完整版

when { tag pattern: "release-*", comparator: "GLOB" }
  • REGEXP: 正则表达式 when { tag pattern: "release=\\\d+", comparator: "REGEXP" }

下面我们来举个例子,我们添加一段参数。

parameters { string(name: 'TEST', defaultValue: 'ABCD', description: 'code is adbcd') }

设置一个when的条件

when { environment name: 'TEST', value: 'ABCD' } steps{ script{ println("获取代码") } } }

构建

image.png

我们可以看到构建成功

image.png

这个时候我们把参数改变,改为abcde

image.png

虽然也构建成功了,但是Checkout阶段被跳过了

parallel并行

声明式流水线的阶段可以在他们内部声明多隔嵌套阶段, 它们将并行执行。 注意,一个阶段必须只有一个 steps 或 parallel的阶段。 嵌套阶段本身不能包含 进一步的 parallel 阶段, 但是其他的阶段的行为与任何其他 stageparallel 的阶段不能包含 agent 或 tools阶段, 因为他们没有相关 steps。

stage("CheckOut"){ failFast true parallel { stage("GetCode"){ steps{ script{ println("获取代码") } } } stage("CheckEnv"){ steps{ script{ println("检查环境") } } } } }

failFast true 当其中一个进程失败时,强制所有的 parallel 阶段都被终止。

这里一定要注意,一般结构是steges里面套了多个步骤也就是套了多个stage,但是呢parallel模块是在stage里面所以,相当于一个stage里面套了多个stage

image.png

并发的构建,从jenkins的页面看的不是很清楚,我们可以Blue Ocean的插件去看,效果如下

image.png

script脚本标签

script步骤需要{scripted-pipline}块并在声明式流水线中执行,对于大多数用例来说,应该声明式流水线中的“脚本”步骤是不必要的,但是它可以提供一个有用的"逃生出口",非平凡的规模和/或复杂性的script块应该被转移到共享库

可以通过此标签嵌入脚本式语法。

stage("Build"){ steps{ script{ println("运行构建") } } } post { success{ script{ println("流水线成功后,要做的事情") currentBuild.description = "\n 构建成功" } }

效果如下

image.png

最后我来总结一下,今天介绍了,三个指令when、parallel和script。Jenkinsfile主要的标签已经介绍完毕。这里需要注意的是它们运行的位置,是在其他指令中,还是在pipline块中。

上一篇:基于gitlab+jenkins+harbor+k8s应用发布方案
下一篇:没有了
网友评论