本文主要是介绍Jenkins高级篇之Pipeline实践篇-3-返回失败的机器的list,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前面一篇我们学习了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_NUMBERpipeline{agent anystages{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 outlines = 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 eerror("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这个单词就应该明白了吧。
这篇关于Jenkins高级篇之Pipeline实践篇-3-返回失败的机器的list的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!