Jenkins使用共享库封装pipeline代码

之前有一个需求,是要在Jenkins的流水线中,调用相关的SDK去执行业务业务逻辑,而且调用SDK会有签名、返回值校验等逻辑

我想将SDK的调用逻辑封装起来,只提供一个入口,而且需要提供一些复用的方法,类似下文这样

scss 复制代码
pipeline {
        agent any
        stages {
            stage('调用sdk') {
                steps {
                    result = sdk.method(param1,param2)
                    if(result.code != 200){
                        error "fail"
                    }
                    var body = toJson(result.body)
                }
            }
        }
    }

可以将代码写到一个库中,然后Jenkins引用这个库达到这个效果

www.jenkins.io/doc/book/pi...

共享库(Shared libraries)是一种可以用来封装函数、变量甚至整个 Pipeline 的机制。通过共享库,可以将常用的功能和流程逻辑定义在单独的 Groovy 脚本中,然后在多个 Pipeline 中重复使用,从而实现代码重用和统一管理

使用方式

less 复制代码
//引入库
@Library('lib')
import com.mycorp.pipeline.somelib.Helper'

//加 _ 就不用import
@Library('lib') _
//使用
def method = new com.mycorp.pipeline.Utils.someStaticMethod()

简单使用

比如说我想复用将返回结果转换成json的方法,这样就可以在多个pipeline中复用

java 复制代码
//tool.groovy
import groovy.json.JsonSlurper

def toJson(result){
    def jsonSlurper = new JsonSlurper()
    return jsonSlurper.parseText(result)
}

//流水线
 steps {
   script {
        var result = callSdk()
        def body = tool.toJson("${result.body}")
   }
 }

封装stage,比如说我这个stage的功能就是调用SDK

scss 复制代码
//callSdk.groovy
def callSdk(param1, param2) {
    var sdk = new sdk();
    var sign = ....;
    var result = sdk.method(sign,param1,param2);
    if(result == ...)
    ...
}
//流水线
@Library('my-shared-library') _
pipeline {
    agent any
    stages {
        stage('My Stage') {
            steps {
                script {
                    callSdk(param1: 'value1', param2: 'value2')
                }
            }
        }
    }
}

封装变量,比如不同环境的变量

ini 复制代码
// test.groovy
def url = 'test.com'


// dev.groovy
def url = 'dev.com'

//流水线
steps {
    script {

        if (env == 'test') {
            config = load 'test.groovy'
        } else if (env == 'dev') {
            config = load 'url.groovy'
        }

        // 使用变量
        def url = config.url
        callSdk(url)
    }
}

可以通过在共享库根目录创建Jenkinsfile,来动态加载pipeline模板

typescript 复制代码
//Jenkinfile
@Library('my-shared-library@1.0.0') _

def env = 'dev' // 环境

//通过参数调用不同的流水线脚本
if (env == 'dev') {
    deployPipeline = libraryResource('deployDev.groovy')
} else if (env == 'test') {
    deployPipeline = libraryResource('deployTest.groovy')
} else {
    echo "Unsupported environment: ${env}"
}

deployPipeline(appName: 'my-app', deploy: true)

// deployDev.groovy
def deployPipeline(Map params) {
    pipeline {
        agent any
        stages {
            stage('Deploy to Dev') {
                when {
                    expression { params.deploy == true }
                }
                steps {
                    sh 'echo "Deploying ${params.appName} to Dev environment..."
                }
            }
        }
    }
}

// deployTest.groovy
def deployPipeline(Map params) {
    pipeline {
        agent any
        stages {
            stage('Deploy to Test') {
                when {
                    expression { params.deploy == true }
                }
                steps {
                    sh 'echo "Deploying ${params.appName} to Test environment..."'
                }
            }
        }
    }
}

通过共享库,可以将复杂的流水线拆分,可以复用函数和动态组合等等,非常灵活

项目结构

erlang 复制代码
project/
├── Jenkinsfile
└── my-shared-library/
    ├── vars/
    │   ├── deployPipeline.groovy
    │   └── ...
    ├── src/
    │   ├── com/
    │   │   ├── example/
    │   │   │   ├── MyClass.groovy
    │   │   │   └── ...
    │   │   └── ...
    │   └── ...
    ├── resources/
    │   ├── deployDev.groovy
    │   ├── deployTest.groovy
    │   └── ...
    └── README.md

vars/ 目录用于存放定义全局变量和流程函数的 Groovy 文件,比如上边复用的函数和封装step的函数

resources/ 目录用于存放资源文件,比如环境变量、配置文件等。比如上边的变量文件

src/ 目录用于存放如自定义的类、函数等,一般是写更复杂的类

需要注意的是vars下的groovy可以使用 Jenkins Pipeline的语法,比如echo、error等函数,在src下,只能写groovy语法的函数

src和resources都可以被vars调用

bash 复制代码
// 使用 load 方法加载 src/com/example/MyClass.groovy
load 'com/example/MyClass.groovy'

// 在 vars/deployPipeline.groovy 中调用 resources/deployDev.groovy
libraryResource 'my-shared-library/deployDev.groovy'

配置共享库

首先要将共享库上传到代码仓库中,Jenkins会拉取共享库并编译加载注意,在jenkins也要安装对应的scm插件

在系统配置中找到Global Pipeline Libraries,选择一个Retrieval method,一般是选择Modern method,需要安装scm插件,这里才有有选项,比如git插件

然后在流水线中配置

如果要使用共享库的Jenkinsfile,需要指定路径

相关推荐
chenbin5202 小时前
Jenkins 自动构建Job
运维·jenkins
java 凯2 小时前
Jenkins插件管理切换国内源地址
运维·jenkins
陆鳐LuLu5 小时前
日志管理利器:基于 ELK 的日志收集、存储与可视化实战
运维·elk·jenkins
[奋斗不止]5 小时前
Jenkins 配置 Credentials 凭证
jenkins·jenkins 配置凭证
[奋斗不止]14 小时前
Jenkins 构建 Unity 打包 .apk 同时生成 .aab
jenkins·jenkins 打包 .aab·jenkins导出aab·jenkisn 导出 apk
boy快快长大14 小时前
【Elasticsearch】同一台服务器部署集群
服务器·elasticsearch·jenkins
深情不及里子14 小时前
纯手工搭建整套CI/CD流水线指南
ci/cd·gitlab·jenkins·harbor
梁萌15 小时前
04-DevOps-安装并初始化Jenkins
运维·jenkins·devops
跳跳的向阳花15 小时前
06、ElasticStack系列,第六章:elasticsearch设置密码
大数据·elasticsearch·jenkins
枫叶落雨2221 天前
08-Elasticsearch
运维·jenkins