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

2024-06-11 11:18

本文主要是介绍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的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1051014

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例