您可以使用Jenkins Pipeline中的构建作业步骤(最小Jenkins要求:2.130)。
下面是构建步骤的完整API: https://jenkins.io/doc/pipeline/steps/pipeline-build-step/
如何使用build:
job:要构建的下游作业的名称。可能是另一个管道工作,但更常见的是一个自由式或其他项目。
如果作业与上游Pipeline作业在同一个文件夹中,请使用简单的名称;
你可以使用相对路径,比如../姐妹文件夹/下游
或者你也可以使用绝对路径,比如/top-level-folder/nested-folder/downstream
使用分支作为参数触发另一个作业
在我的公司,许多分支机构都包含“/”。必须将“/”的任何实例替换为“%2F”(因为它出现在作业的URL中)。
在本例中,我们使用相对路径
stage('Trigger Branch Build') {
steps {
script {
echo "Triggering job for branch ${env.BRANCH_NAME}"
BRANCH_TO_TAG=env.BRANCH_NAME.replace("/","%2F")
build job: "../my-relative-job/${BRANCH_TO_TAG}", wait: false
}
}
}
使用构建号作为参数触发另一个作业
build job: 'your-job-name',
parameters: [
string(name: 'passed_build_number_param', value: String.valueOf(BUILD_NUMBER)),
string(name: 'complex_param', value: 'prefix-' + String.valueOf(BUILD_NUMBER))
]
并行触发许多作业
来源:https://jenkins.io/blog/2017/01/19/converting-conditional-to-pipeline/
更多关于Parallel的信息请访问:https://jenkins.io/doc/book/pipeline/syntax/#parallel
stage ('Trigger Builds In Parallel') {
steps {
// Freestyle build trigger calls a list of jobs
// Pipeline build() step only calls one job
// To run all three jobs in parallel, we use "parallel" step
// https://jenkins.io/doc/pipeline/examples/#jobs-in-parallel
parallel (
linux: {
build job: 'full-build-linux', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
mac: {
build job: 'full-build-mac', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
windows: {
build job: 'full-build-windows', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
failFast: false)
}
}
或者:
stage('Build A and B') {
failFast true
parallel {
stage('Build A') {
steps {
build job: "/project/A/${env.BRANCH}", wait: true
}
}
stage('Build B') {
steps {
build job: "/project/B/${env.BRANCH}", wait: true
}
}
}
}