TL;DR:显然在 Jenkins 管道作业中,您可以轻松地向下游传递参数。我想知道的是你能不能通过他们上游 .
用例:
我们有三份工作; job_one
, job_two
, 和 job_three
.这些通常单独运行,因为只需要一个阶段,但在越来越频繁的情况下,我们希望能够背靠背运行所有三个阶段。
第一个和第二个依赖于您可以提前定义的参数,但第三个需要从第二个作业生成的参数(在 job_two 运行之前其结构未知的文件名)。
我建了 umbrella
,它为每个作业调用如下内容。在这种情况下,PARAM1
填充是因为雨伞作为“带参数构建”运行。
build job: 'job_one', parameters: [[$class: 'StringParameterValue', name: 'PARAM1', value: "$PARAM1"]]
一切顺利,然后我可以使用
PARAM1
在 job_one
正好。问题:
对于
job_three
我需要参数 filename
.这是在 job_two
内生成的,因此据我所知是无法访问的,因为 job_three 不知道 job_two 在做什么。在理想的世界中,我只会让 job_two 通过
filename
到伞作业,这会将其反馈到 job_three。因此,我如何传递生成的 filename
回到伞的工作? 我正在想象这样的最终脚本;
node('on-demand-t2small'){
stage ('Build 1') {
build job: 'job_one', parameters: [[$class: 'StringParameterValue', name: 'PARAM1', value: "$PARMA1"]]
}
stage ('Build 2') {
build job: 'job_two', parameters: [[$class: 'StringParameterValue', name: 'PARAM2', value: "$PARMA2"]]
//somehow get the filename parameter out of job_two here so that I can move it to job three...
}
stage ('Build 3') {
build job: 'job_three', parameters: [[$class: 'StringParameterValue', name: 'filename', value: "$filename"]]
} }
补充说明:
我认识到第一个问题是“为什么不让 job_two 触发 job_three?我不能以这种方式设置系统有两个原因;
我曾考虑将参数设置为环境变量,但我相信这是特定于节点的,我不能保证两个作业都会在同一节点上运行,因此这似乎不是解决方案。
Umbrella 是用 groovy 编写的流水线作业,其他三个可能是流水线作业或自由式作业,如果这很重要的话。
如果可能,我希望得到详细的答案,我对 Groovy、Jenkins 和一般的编码仍然是新手。
最佳答案
应该就是这么简单:
stage ('Build 3') {
res = build job: 'job_three', parameters: [[$class: 'StringParameterValue', name: 'filename', value: "$filename"]]
echo "$res.buildVariables.filename"
}
假设在 job_three 你做
env.filename = "col new file name"
关于jenkins - 管道作业 - 向上游传递参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41513072/