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

Posted 小圆和他的朋友们

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了流水线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  

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("获取代码")
                
            
        

构建

我们可以看到构建成功

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

虽然也构建成功了,但是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

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

script脚本标签

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

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

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

    

效果如下

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

以上是关于流水线pipeline招式之声明式(后篇)的主要内容,如果未能解决你的问题,请参考以下文章

Spring(十五)之声明式事务

Jenkins系列-Pipeline语法全集

Spring之声明式事务

jenkins的Pipeline代码流水线管理

spring笔记--事务管理之声明式事务

数据库事务之声明式事务