1、退出pipeline执行步骤
场景描述:在执行jenkins pipeline我们有时会需要退出执行。比如git项目:clone->build->deploy,我需要获取触发JOB时的代码与前一次执行代码的增量文件,但如果触发时git rev-parse HEAD与前一次执行的commitId号是相同的,那么文件无变更的情况下就没必要继续执行build和deploy。
node("master"){
stage('clone'){
}
if(xx=xx){
return
}
stage('build'){
}
stage('deploy'){
}
}
这里需要注意return需要放在stage外面,否则无效会继续执行build和deploy。
2、判断文件是否存在
场景描述:在执行jenkins pipeline时,我们有时会去判断一个文件是否存在,这里有几种方式
node('master'){
//判断工作空间下a.log文件是否存在
if(fileExists("${WORKSPACE}/a.log")){
//文件存在
}
}
node('master'){
//判断工作空间下a.log文件是否存在
def status = sh returnStatus: true,script: "ls a.log"
//文件存在为0
}
3、管理服务器信息
场景描述:pipeline执行中,可能涉及到一些参数的定义和读取,当这些参数过多的时候,在pipeline上会影响到代码的美观和不便于理解。比如应用部署:服务器的IP、访问用户、部署目录、启停脚本、判活脚本、数据库ip、账号密码等等信息。
一种解决方法是将这些信息统一记录到一个文件中去,每个参数对应一行,然后通过key=value的形式记录,对于不便于表达的参数做描述说明。pipeline通过解析方法获取参数值。
信息记录文件如:
#U8环境部署服务器信息
XX_U8_ips=127.0.0.1,127.0.0.2
XX_U8_user=test
XX_U8_deployDir=/home/test/
......
解析方法
//解析方法
def parseConfigFile(configContent){
def configMap = [:]
def configArr = configContent.split("\n")
for(int i = 0;i<configArr.length;i++){
def configLine = configArr[i].trim()
if(!"".equals(configLine)){
if(!configLine.startWith("#")){
def lineArr = configLine.split("=")
def configKey = lineArr[0]
def configVal = lineArr[1]
configMap.put(configKey,configVal)
}else{
//剔除注释行
}
}
}
return configMap
}
//调用方法 文件为工作空间下xx.config
def configContent = sh returnStdout: true, script: "cat ${WORKSPACE}/xx.config"
def configMap = parseConfigFile(configContent)
//获取值信息
def ips = configMap["XX_U8_ips"]
4、获取执行时间
我们有时会需要查看一下具体步骤的操作时间,用来优化流水线执行步骤。可以通过安装Timestamper插件来实现。以下是未安装插件和安装插件之后的比对。
需要注意的是:安装插件后并不会直接在console output中展示
单一job实现日志展示,可以在jenkinsfile中包一层timestamps方法。
所有job实现,可以在系统管理》系统配置中选上Enabled for all Pipeline builds。(无需修改pipeline脚本)