Jenkins 构建下游项目时参数化触发

Parameterized Trigger

官网地址:Parameterized Trigger

此插件可让您在构建完成时触发新构建,并通过多种方式为新构建指定参数。

当您查看触发它们的项目时,这些新构建在 Jenkins UI 中显示为 “子项目”。

您可以添加多个配置:每个配置都有一个要触发的项目列表、何时触发它们的条件(基于当前构建的结果)和一个参数部分。

如果您想在不同的远程 Jenkins 控制器上触发构建,还有一个参数化远程触发插件。

参数部分可以包含以下一项或多项的组合:

  • 一组预定义的属性
  • 从触发构建的工作区读取的属性文件中的属性
  • 当前构建的参数
  • Subversion 修订版:确保触发的项目是使用与触发构建相同的修订版构建的。您仍然必须确保这些项目实际配置为签出正确的 Subversion URL。
  • 将矩阵执行限制为子集:允许您指定与在矩阵项目配置中使用的相同的组合过滤器表达式,并进一步限制要运行的下游矩阵构建的子集。

参数部分本身是可插入的,其他插件可以贡献其他参数来源。

这种触发机制既可以用作构建后步骤,也可以用作构建步骤,在这种情况下,您还可以阻止触发构建的完成。这使您可以创建类似语义的 “函数调用”。

警告:您必须通过此项目是参数化属性在下游作业中定义参数。例如:如果 job1 传递 ABC=123job2,则在 job2 中将作业标记为 This project is parameterized 并添加一个名为 ABC 的参数。

用作构建步骤

当在另一个项目项上使用触发器/调用时。

如果触发器配置为启用 “阻止直到触发的项目完成其构建”,则以下环境变量可用于进一步的构建步骤。

未来构建步骤的环境变量:

  • LAST_TRIGGERED_JOB_NAME- 上一个项目开始
  • TRIGGERED_BUILD_NUMBER_<project name>- 上次触发的内部版本号(自 2.17 起)
  • TRIGGERED_JOB_NAMES- 所有触发项目的逗号分隔列表
  • TRIGGERED_BUILD_NUMBERS_<project name>- 逗号分隔的版本号列表触发
  • TRIGGERED_BUILD_RESULT_<project name>- 项目的最后触发构建结果
  • TRIGGERED_BUILD_RESULT_<project name>*RUN*<build number>- 构建编号的触发构建结果
  • TRIGGERED_BUILD_RUN_COUNT_<project name>- 为项目触发的构建数量

从 2.17 开始:所有项目名称的字符都不是 a-zA-Z0-9 替换为:_(multiple characters are condensed into a single)

请注意,使用 BuildStep 可以将变量用于项目名称 IE ${projectName}

在 Matrix 作业中使用插件

后期构建任务

当使用触发参数化构建作为矩阵作业的构建后任务时,将在所有不同的矩阵配置完成后完成一次触发。在这种情况下,某些环境变量可能无法解析,因为将它们传递给下游作业将失败。您也不能使用变量作为下游项目名称。如果需要此功能,则必须使用 BuildStep

应该可用的环境变量是默认的 shell 变量(<yourserver:port>/env-vars.html)和定义为参数的变量。其他插件作为构建包装器添加的变量可能不可用。

构建步骤

当使用触发器参数化构建作为构建步骤时,它将为每个不同的配置调用,因此如果触发另一个没有参数的项目,它将执行与您的配置相同的次数,可能导致触发的作业运行多次.

但是,这也允许您使用与当前配置相关的参数触发其他作业,即在具有相同 JDK 的同一节点上触发构建。

为该插件提供其他参数类型的插件

  • Git Plugin
  • NodeLabel Parameter Plugin

向后兼容 2.22 版

  • Parameterized Trigger 2.23 开始,在某些情况下,Parameterized Trigger 无法触发下游构建,而 Parameterized Trigger <= 2.22 可以成功触发这些构建。

    • 这是由参数化触发器 2.23 中引入的新行为引起的。它不直接将参数值传递给下游构建,而是传递给下游项目的参数定义。这使参数定义能够执行其特定的过程,例如:使用 NodeLabel 参数插件选择节点。
  • 示例:有一个带有选项 A、B、C 选项的项目参数。当您使用参数值 D 触发该项目时,它会在上游失败并显示以下输出:

    java.lang.IllegalArgumentException: Illegal choice: D at
    hudson.model.ChoiceParameterDefinition.checkValue(ChoiceParameterDefinition.java:72)
    
  • 这被视为指定行为。

    • 因为这些故障是由参数定义设计的。例如:choice 参数被设计为不接受意外值。
    • 当您使用 Jenkins CLI 或远程访问 API 触发这些构建时,您将面临同样的问题。
  • 建议修复您的项目配置以使参数定义不会失败。

    • 例如,使用 EnvInject 插件来处理值或使用可扩展选择参数插件,它提供了一个接受编辑值的选择参数。

解决方法

作为向后兼容性,您可以通过将 Java 系统属性设置 hudson.plugins.parameterizedtrigger.ProjectSpecificParametersActionFactory.compatibility_modetrue。可以通过启动 Jenkins 来完成,如下所示:

java -Dhudson.plugins.parameterizedtrigger.ProjectSpecificParametersActionFactory.compatibility_mode=true -jar jenkins.war

在 RedHat Linux 系统中,您可以修改 /etc/sysconfig/jenkins 如下:

-JENKINS\_JAVA\_OPTIONS="-Djava.awt.headless=true"
+JENKINS\_JAVA\_OPTIONS="-Djava.awt.headless=true -Dhudson.plugins.parameterizedtrigger.ProjectSpecificParametersActionFactory.compatibility_mode=true"

在 Debian Linux 系统中,您可以修改 /etc/defaults/jenkins 如下:

-JAVA_ARGS="-Djava.awt.headless=true" # Allow graphs etc. to work even when an X server is present
+JAVA_ARGS="-Djava.awt.headless=true -Dhudson.plugins.parameterizedtrigger.ProjectSpecificParametersActionFactory.compatibility_mode=true"

在 Windows 系统中,可以修改安装文件夹中的 jenkins.xml

-<arguments>-Xrs -Xmx256m -Dhudson.lifecycle=hudson.lifecycle.WindowsServiceLifecycle -jar "%BASE%\\jenkins.war" --httpPort=8080\</arguments>
+\<arguments>-Xrs -Xmx256m -Dhudson.lifecycle=hudson.lifecycle.WindowsServiceLifecycle -Dhudson.plugins.parameterizedtrigger.ProjectSpecificParametersActionFactory.compatibility_mode=true -jar "%BASE%\\jenkins.war" --httpPort=8080\</arguments>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Jenkins 中,可以使用参数构建来动态地设置构建参数参数构建可以允许用户在构建过程中输入参数值,这些参数值可以在 Pipeline 脚本中使用。 如果你想在 Pipeline 中使用参数构建触发下游分支的构建,可以按照以下步骤操作: 1. 首先,在 Jenkins 中创建一个参数构建,为下游分支指定构建参数。 2. 然后,使用 Pipeline 脚本中的 `build` 命令触发下游分支的构建,并将构建参数传递给下游分支。例如: ``` build job: '下游分支名称', parameters: [string(name: '参数名', value: "${params.参数名}")] ``` 在上面的命令中,`${params.参数名}` 表示从参数构建中获取参数值。 3. 最后,将上述命令放入 Pipeline 脚本中的需要触发下游分支的位置。这样,当 Pipeline 运行到该位置,它将触发下游分支的构建并传递构建参数。 希望这些信息能够帮助你实现 Jenkins Pipeline 参数构建下游分支。 ### 回答2: Jenkins的Pipeline是一种用于定义和管理持续集成和交付流程的插件。参数构建是指可以在Jenkins的Pipeline中定义和使用各种参数,使得构建过程更加通用和灵活。下游分支是指在构建过程中需要执行的后续任务或流程。 在Jenkins Pipeline参数构建下游分支,可以通过在Pipeline脚本中定义并使用参数,来实现对下游分支的控制和调用。首先,在Pipeline的开始处,可以通过参数定义来指定需要使用的参数类型,如字符串、布尔值等。然后,在Pipeline的执行过程中,可以利用这些参数的值来决定是否需要执行下游分支。 具体来说,通过在Jenkins Pipeline脚本中定义参数,并使用参数值来调用不同的下游分支,可以实现条件分支的机制。例如,可以定义一个布尔类型的参数isReleased,来表示是否进行发布操作。在Pipeline的执行过程中,根据isReleased参数的值,可以使用if-else语句来决定是否执行发布相关的下游分支。如果isReleased为真,就执行发布分支;如果isReleased为假,就跳过发布分支,执行其他操作。 此外,Jenkins Pipeline还提供了很多内置的参数类型和函数,可以进行更复杂的条件判断和流程控制,例如根据不同的参数值执行对应的下游分支、使用参数值来动态生成分支名称等。可以根据具体的需求和场景,结合Jenkins Pipeline的语法和功能来灵活地构建和管理下游分支。 ### 回答3: 在Jenkins中,Pipeline参数构建是一种非常有用的功能。通过参数构建,我们可以在执行Pipeline传递不同的参数值,从而控制构建的行为。 下游分支是指Pipeline中被触发的后续步骤或任务。通常情况下,我们可以通过在Pipeline中定义具有不同参数选项的阶段来实现参数构建下游分支的目的。 首先,我们需要在Jenkins中创建一个Pipeline项目,并在项目的配置中启用参数构建。然后,我们可以在Pipeline脚本中定义参数选项,例如使用parameters{}块来定义字符串参数、布尔参数或选择参数。这些参数选项将根据用户的输入值来控制后续步骤的执行。 在Pipeline的某个阶段中,我们可以使用if语句或switch语句来根据参数触发不同的下游分支。例如,我们可以根据参数值执行不同的构建、部署、测试或通知操作。 在实际的Pipeline脚本中,我们可以使用Jenkins提供的Pipeline Syntax工具来生成参数构建的代码片段。我们可以通过选择所需的参数类型、填写参数的名称和描述,然后点击"生成Pipeline脚本"按钮来生成相关的Groovy代码。我们只需将生成的代码粘贴到Pipeline脚本中相应的位置即可。 参数构建下游分支可以使我们的Pipeline更加灵活和可配置。通过在Pipeline中设置参数选项,并根据用户的输入值触发不同的下游分支,我们可以根据不同的需求和场景来自定义和调整构建过程。这种方式能够提高Pipeline的可重用性和可扩展性,使我们的CI/CD流程更加智能和自动

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值