33

我目前正在测试 Jenkins 2.0 的流水线方法,看看它是否适用于我正在使用的构建环境。

首先是环境本身。它目前由多个 SCM 存储库组成。每个存储库包含多个分支,用于开发的不同阶段,每个分支都使用多种配置构建。并非所有配置都适用于每个存储库。

目前,每个存储库/分支都设置为不同配置的矩阵项目。每个项目都将其构建结果公开为工件,并且这些工件用于下游项目。

不同的存储库相互依赖,因此上游作业的成功构建会触发一些特定的下游作业。目前一切正常,但设置新分支或调整构建过程所需的工作量很大,因为需要手动更改许多不同的项目。

现在我想尝试一下新的管道。我的想法是创建多分支管道项目,并Jenkinsfile在存储库中放置一个包含构建指令的存储库。

主要问题是让构建相互触发,因为基本上特定上游分支中的构建需要触发下游分支。上游项目不知道需要触发哪些下游分支的信息。每个下游项目都从一些上游分支获取工件,理想的解决方案是如果作为工件源的上游构建完成它的构建,将触发下游构建。

问题是只有下游项目真正知道他们需要什么工件。在大多数情况下,分支名称不太可能匹配,这使得从上游项目触发构建非常困难。

目前,这是使用ReverseBuildTrigger. 但是,一旦它靠近管道,它就会停止工作。

我真的很茫然如何让这个工作。有什么办法可以得到类似于ReverseBuildTrigger在管道脚本中工作的东西吗?

如果上游单个分支发生更改,也不能触发所有分支的整个下游构建。这将创建太多相同的构建。

4

3 回答 3

51

如果您使用的是声明性多分支管道,则可以使用:

triggers {
  upstream(upstreamProjects: "some_project/some_branch", threshold: hudson.model.Result.SUCCESS)
}

如果您希望跨依赖项发生分支匹配,您可以使用:

triggers {
  upstream(upstreamProjects: "some_project/" + env.BRANCH_NAME.replaceAll("/", "%2F"), threshold: hudson.model.Result.SUCCESS)
}
于 2017-05-09T18:06:53.620 回答
15

我目前正试图让它为我们的部署工作。我最接近的是将以下内容添加到下游的 Jenkinsfile 中;

properties([
    pipelineTriggers([
        triggers: [
            [
                $class: 'jenkins.triggers.ReverseBuildTrigger',
                upstreamProjects: "some_project", threshold: hudson.model.Result.SUCCESS
            ]
        ]
    ]),
])

这至少让 Jenkins 承认它应该在构建“some_project”时触发,即它出现在“查看配置”页面中。

然而,到目前为止,“some_project”的构建仍然没有按预期触发下游项目。

话虽如此,也许你会有更多的运气。请让我知道这对你有没有用。

(有人问过类似的问题Jenkins 多分支管道和指定上游项目

于 2016-08-31T14:41:09.707 回答
3

Pipeline Job配置仍然原生支持Build Triggers,包括反向构建触发器,构建其他项目后构建。您甚至可以从Pipeline Multi-branch项目中指定一个分支。

不幸的是,反向触发不可用Pipeline Multi-branch作业。最接近反向触发的方法是使用Promoted Builds Plugin。但它仍然不允许您配置每个分支设置。

此外,片段生成器还阐明:

以下变量当前在 Pipeline 脚本中不可用:

NODE_LABELS WORKSPACE SCM 特定变量,例如 SVN_REVISION

附言。也许唯一的方法是从上游提示到下游

于 2016-04-24T20:40:25.647 回答