继续来学习basic pipeline这个插件的提供的方法,本篇主要学习timeout和waitUntil两个关于时间监控的方法。有时候,我们需要对一个stage执行时间进行精确监控。例如执行这个stage大概20分钟一定可以完成,那么我们就可以使用timeout 设置20分钟,如果操作20分钟还没有执行结束,那么当前这个pipeline stage就会被自动取消,状态显示为aborted。而waitUntil是一个等待一个条件出现就会终止执行等待的方法。下面我分别用一个简单例子来代码演示。withEnv是设置环境变量的,有时候我们还会设置一些普通变量放这个位置。

1.方法timeout

叫方法或者指令都可以,timeout的基本格式如下,例如我有一个代码块执行监控执行时间,那么放在timeout(){...}就好,

time(时间设置,默认是分钟为单位) {
    // 需要监控的代码执行
}

我写一个一分钟超时的简单代码。

import hudson.model.*;

println env.JOB_NAME
println env.BUILD_NUMBER

pipeline{
	
	agent any
	stages{
		stage("init") {
			steps{
				script {
					timeout(1) {
					    sh('java -version')
					    //sleep 61
					}
				}
			}
		}
	}
}

上面我没有执行sleep语句,那么这个打印java -version的代码肯定能在一分钟之内完成,这个job执行的状态是成功。那么,如果我取消sleep这个前面注释,也就是这个代码要执行61秒以上的时间,但是我给了timeout是1分钟,那么这个job跑起来就会自动cancel,状态是aborted。

日志如下:

[Pipeline] {
[Pipeline] timeout
Timeout set to expire in 1 min 0 sec
[Pipeline] {
[Pipeline] sh
[pipeline_basic_steps] Running shell script
+ java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-b13)
OpenJDK Server VM (build 25.181-b13, mixed mode)
[Pipeline] sleep
Sleeping for 1 min 1 sec
Cancelling nested steps due to timeout
[Pipeline] }
[Pipeline] // timeout
[Pipeline] }
[Pipeline] // script
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
Timeout has been exceeded
Finished: ABORTED

2.方法waitUntil

在waitUntil{...}里面的代码会无限制循环执行下去,直到返回true,如果返回是false,会在很短时间内再次尝试,没有尝试次数限制,如果有异常,会退出。这个我没有实际用过,不好举例。

import hudson.model.*;

println env.JOB_NAME
println env.BUILD_NUMBER

pipeline{
	
	agent any
	stages{
		stage("init") {
			steps{
				script {
					timeout(5) {
					     waitUntil {
                                                 script {
                                                      // 监控某一个服务是否启动完成代码
                                                 }
                                             }
					}
				}
			}
		}
	}
}

我没有想出一个实际例子,这里写一个伪代码。场景就是,在5分钟之内,我使用waitUntil去一直轮询检查某一个服务是否启动完成。

3.withEnv

import hudson.model.*;

println env.JOB_NAME
println env.BUILD_NUMBER

pipeline{
	
	agent any

	stages{
		stage("init") {
			steps{
			    withEnv(['java_home=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.181-3.b13.el6_10.i386/jre']) {
	                sh("$java_home/bin/java -version")
        	    }
				script {
					println "test with withEnv feature"
				}
			}
		}
	}
}

这个用withEnv添加多个环境变量,我没有使用过,下次如果遇到再补上。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐