干货!Pipeline脚本稳定运行的核心设计思路

如果想要CI/CD持续稳定的运行,那么pipeline脚本的稳定性就是最核心的问题,那么如何才能让pipeline脚本稳定的运行呢?就是应用异常!这里以脚本化Pipeline script为例进行讲解,如果您使用声明式pipeline script,请把异常处理机制放在script {}中(这里不对声明式pipeline script做详细介绍)。

创新互联主营矿区网站建设的网络公司,主营网站建设方案,成都app软件开发公司,矿区h5小程序开发搭建,矿区网站营销推广欢迎矿区等地区企业咨询

编码式Pipline的异常使用

Pipeline 处理异常的形式如下:

 
 
 
 
  1. node { 
  2. sh './set-up.sh' 
  3. try { 
  4. sh 'might fail' 
  5. echo 'Succeeded!' 
  6. } catch (err) { 
  7. echo "Failed: ${err}" 
  8. } finally { 
  9. sh './tear-down.sh' 
  10. echo 'Printed whether above succeeded or failed.' 

异常通用概念

在这里需要介绍一下异常相关的基础概念:

Exception

检查性异常:最具代表的检查性异常是用户错误或问题引起的异常,这是程序员无法预见的。例如要打开一个不存在文件时,一个异常就发生了,这些异常在编译时不能被简单地忽略。

运行时异常:运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。

Error

错误:错误不是异常,而是脱离程序员控制的问题。错误在代码中通常被忽略。例如,当栈溢出时,一个错误就发生了,它们在编译也检查不到的。下图显示了如何组织Groovy中的异常层次结构。它都基于Java中定义的层次结构。

try和catch的使用

方法使用try和catch关键字的组合捕获异常。 try/catch块放在可能生成异常的代码周围。

 
 
 
 
  1. try{ 
  2. //保护的代码 
  3. } catch(ExceptionName e1) { 
  4. //处理异常的代码 

 可以有多个catch块来处理多种类型的异常。对于每个catch块,根据引发的异常类型,您将编写代码来相应地处理它。

 
 
 
 
  1. try { 
  2. def arr = new int[3]; 
  3. arr[5] = 5; 
  4. catch(ArrayIndexOutOfBoundsExceptionex) { 
  5. println("捕获Array out of Bounds exception"); 
  6. catch(IOException ex) { 
  7. println("捕获 io exception"); 

 结果输出

捕获Array out of Bounds exception

finally块

finally块遵循try块或catch块。无论发生异常,最终都会执行最后一段代码。

 
 
 
 
  1. try { 
  2. def arr = new int[3]; 
  3. arr[5] = 5; 
  4. catch(ArrayIndexOutOfBoundsExceptionex) { 
  5. println("捕获Array out of Bounds exception"); 
  6. catch(IOException ex) { 
  7. println("捕获 io exception"); 
  8. finally{ 
  9. println("执行final 块"); 

 结果输出

捕获Array out of Boundsexception

执行final块

备注:如果大家不确认具体的异常类型直接使用exception(或者exp)就可以,因为它是各种exception的父类!

error的处理

当我们需要处理错误(错误不是异常,而是脱离程序员控制的问题。)的时候,就需要使用error(或者err)了。

 
 
 
 
  1. try { 
  2. //保护的代码 
  3. catch(error) { 
  4. //处理错误的代码 

稳定代码的设计核心点

如果想使我们的代码稳定运行,既处理异常又捕获error,可以这样处理

 
 
 
 
  1. try { 
  2. //保护的代码 
  3. catch(err) { 
  4. //处理错误的代码 
  5. catch(exp){ 
  6. //处理异常的代码 

 在pipeline中的应用如下所示,这样设计可以确保我们的pipeline稳定运行。

 
 
 
 
  1. node { 
  2. try { 
  3. //pipeline运行的脚本 
  4. catch(err) { 
  5. //处理pipeline中代码的异常 
  6. catch(exp){ 
  7. //处理pipeline中遇到的错误信息 

网站名称:干货!Pipeline脚本稳定运行的核心设计思路
网站URL:http://www.shufengxianlan.com/qtweb/news8/407608.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联