您可以使用Jenkins Pipeline中的build job
步骤(最低Jenkins要求:2.130)。
这是该build
步骤的完整API :https : //jenkins.io/doc/pipeline/steps/pipeline-build-step/
使用方法build
:
job
:要构建的下游作业的名称。可能是另一项Pipeline工作,但更常见的是自由泳或其他项目。
- 如果作业与此上游Pipeline作业位于同一文件夹中,请使用简单名称;否则,请使用简单名称。
- 您可以改用相对路径,例如
../sister-folder/downstream
- 或者你可以使用绝对路径,像
/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/
有关并行的更多信息,请访问: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
}
}
}
}