Jenkins高级篇之Pipeline实践篇-3-返回失败的机器的list

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011541946/article/details/85041734

前面一篇我们学习了split()和tokenize()两个切片方法的区别,这篇练习,你可以用这两个进行练习。我们还是在linux机器上来做小练习。需求,在一个大型软件自动化运维中,如某一个节点机器运维操作失败,会在路径/tmp/test下产生一些文件。这些文件,可能表示android,ios,mysql,ngix,tomcat等服务器升级失败或者成功。具体规则是这样,出现DB_12.status,表示mysql数据库升级失败,如果出现ANDROID_2_STARTED.status,表示android服务器没有失败。

1.数据准备

根据上面规则,我准备如下测试数据

[root@Anthony ~]# ls /tmp/test | grep .status
ANDROID_2.status
DB_1_STARTED.status
IOS.status
TOMCAT.status
WEB_1.STARTED.status

根据规则,我们应该得到 [android, ios, tomcat]

2.代码

需求分析:我们第一步要拿到所有的.status文件,不保证该路径下还有其他非status文件;第二部,判断status不包含STARTED的字符串;第三步是,返回具体host的一个list,例如ANDROID就返回android,WEB就返回ngix等。第三点,根据具体实际业务,写返回,只要后续能根据这个返回结果,看得懂就行。

import hudson.model.*;

println env.JOB_NAME
println env.BUILD_NUMBER

pipeline{
	
	agent any
	stages{
		
		stage("git checkout") {
			steps{
				script {
					checkout([$class: 'GitSCM', branches: [[name: '*/master']],
						userRemoteConfigs: [[credentialsId: '6f4fa66c-eb02-46dc-a4b3-3a232be5ef6e', 
							url: 'https://github.com/Anthonyliu86/HelloWorld.git']]])
				}
			}
		}
		stage("Get failure node") {
			steps {
				script {
					
					try{
					    failure_node_list = []
					    out = sh(script:" ls /tmp/test | grep .status ", returnStdout: true).toString().trim()
					    println out
					    lines = out.split("\n")
					    lines.each { 
					        if(!it.contains("STARTED")) {
					             if(it.startsWith("ANDROID")){
					                 failure_node_list.add("android")
					             }else if(it.startsWith("IOS")){
					                 failure_node_list.add("ios")
					             }else if(it.startsWith("DB")){
					                 failure_node_list.add("mysql")
					             }else if(it.startsWith("TOMCAT")){
					                 failure_node_list.add("tomcat")
					             } else if(it.startsWith("WEB")){
					                 failure_node_list.add("ngix")
					             }else {
					                 println "unknow host type."
					             }

					        }

					    }
					    println failure_node_list.toString()
					    
					} catch(Exception e) {
						println e
						error("fond error during get failure node.")
					}
				}
			}
		}
	}
}

测试结果:

[Pipeline] stage
[Pipeline] { (Get failure node)
[Pipeline] script
[Pipeline] {
[Pipeline] sh
[pipeline_basic_steps] Running shell script
+ grep .status
+ ls /tmp/test
[Pipeline] echo
ANDROID_2.status
DB_1_STARTED.status
IOS.status
TOMCAT.status
WEB_1.STARTED.status
[Pipeline] echo
[android, ios, tomcat]
[Pipeline] }
[Pipeline] // script
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
Finished: SUCCESS

提醒一下,我是写这个代码过程,一个小失误,就造成了null,什么都是null,无法判断,返回List也是空。就是在执行sh命令,少些了一个参数returnStdout: true, 这个你可以试一下少了这个参数的效果,也可以思考下为什么会得到null,看到return这个单词就应该明白了吧。

猜你喜欢

转载自blog.csdn.net/u011541946/article/details/85041734
今日推荐