保障Pipeline脚本在Devops中成功应用的四大核心

保障pipeline脚本在DevOps中成功应用的四大核心

作者:测试开发Kevin 2021-10-15 09:16:05

云计算 想设计复杂的pipeline脚本在devops中成功应用,我们需要从脚本的稳定性.脚本执行的超时处理.构建结果处理.对于groovy脚本的调用四个方面进行考虑。

想设计复杂的pipeline脚本在devops中成功应用,我们需要从如下几个方面进行考虑:

1.脚本的稳定性:使用异常处理机制保证在发生异常的情况下脚本能够捕获异常并持续运行;

2.脚本执行的超时处理:构建时需要考虑超时机制避免花费大量时间等待而浪费执行时间;

3.构建结果处理:通过异常处理机制,Jenkins build的结果都是SUCCESS,如果想对build的结果或者是stage的结果进行控制分析,我们需要进一步对构建结果进行处理;

4.对于groovy脚本的调用:引入其他groovy脚本来实现某些更为复杂的功能

代码的设计基础样式

写一个脚本的通常形式是

  
 
 
  1. node {
  2. stage('Build') {
  3. // git 下载代码
  4. // mvn clean install 构建代码
  5. }
  6. stage('unit Test') {
  7. // 执行单元测试
  8. }
  9. stage('Test') {
  10. // 执行自动化测试脚本,进行核心功能覆盖
  11. }
  12. stage('Deploy') {
  13. //执行运维脚本,部署程序上线
  14. }
  15. }

对脚本进行稳定性处理

  
 
 
  1. stage('Test'){
  2. try {
  3. //需要处理的代码
  4. }catch(err) {
  5. //处理error的代码
  6. }
  7. catch(exp) {
  8. //处理exception的代码
  9. }

脚本执行超时的处理

某些场景我们需要对脚本进行超时处理,例如maven构建超时、测试代码执行超时等等,那么我们可以这样设计代码。

  
 
 
  1. try {
  2. timeout(timeout) {
  3. //超时处理的代码
  4. }
  5. }
  6. catch (exp) {
  7. //捕获超时异常,便于大家做进一步的处理
  8. def error_msg = exp.getCauses()[0].toString()
  9. if (error_msg.find("TimeoutStepExecution") =="TimeoutStepExecution") {
  10. //处理逻辑
  11. }
  12. }

构建结果的处理

通过使用try… catch…的处理,jenkins build的结果都是SUCCESS,如果想对build的结果或者是stage的结果进行控制,可以按照下面的方法进行处理:

build结果包括:SUCCESS, UNSTABLE,或者FAILURE (返回null ,build正在进行中)

使用变量currentBuild.result可以设置build的最终结果

currentBuild.result =‘FAILURE’//设置build结果为失败

对各个stage的结果处理,需要使用catchError

catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') {}//设置build结果为成功,而改stage结果为失败

引入其他groovy脚本

调用groovy类中的api

  
 
 
  1. ClassDemo.groovy
  2. class MyClass {
  3. void test1() {
  4. println("test1")
  5. }
  6. static void test2() {
  7. println("test2")
  8. }
  9. }
  10. return new MyClass()

注意一定要给调用者一个返回值,即return new MyClass()返回一个实例

调用groovy脚本中的函数

  
 
 
  1. Demo.groovy
  2. def fun1(){
  3. println("func1")
  4. }
  5. def fun2(){
  6. fun1()
  7. println("func2")
  8. }
  9. def fun3(){
  10. fun1()
  11. println("func3")
  12. }
  13. return this

同样注意一定要给调用者一个返回值,即return this

在pipeline中调用groovy脚本

使用load引入脚本即可,代码如下

  
 
 
  1. node {
  2. def f=load ("/opt/scripts/test/Demo.groovy")
  3. f.fun1()
  4. def f2=load ("/opt/scripts/test/ClassDemo.groovy")
  5. f2.test1()
  6. }

jenkins share libary方式

可以使用share的方法,请参考官方文档:

https://www.jenkins.io/doc/book/pipeline/shared-libraries/

本文名称:保障Pipeline脚本在Devops中成功应用的四大核心
URL网址:http://www.mswzjz.cn/qtweb/news41/336191.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

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