4

我有一个跨越多个部署组的复杂版本,我计划使用第 3 方vsts-git-release-tag扩展来标记该版本。理想情况下,整个发布(所有作业)在标记存储库之前首先会成功。

因此,我正在尝试找出实现这一目标的最佳方法。如果这是一个构建管道而不是部署管道,很明显我可以使用 来dependsOn安排它们,如下所示。

jobs:
- job: Deployment_Group_1
  steps:
  - script: echo hello from Deployment Group 1
- job: Deployment_Group_2
  steps:
  - script: echo hello from Deployment Group 2
- job: Tag_Repo
  steps:
  - script: echo this is where I would tag the Repo
  dependsOn:
  - Deployment_Group_1
  - Deployment_Group_2

但是,在本文档中指定的发布管道中似乎没有等效的功能(至少目前是这样)。

笔记

目前仅在构建管道中支持并行运行多个作业。发布管道尚不支持它。

虽然它没有特别提到该dependsOn功能,但似乎没有办法在发布管道中使用它(如果我错了,请纠正我)。

我意识到我可能可以创建一个单独的阶段,其中包含一个作业和任务来创建 Git 标签,但这感觉就像一个 hack。在所有其他发布作业完成后,是否有更好的方法来运行特定发布作业?

4

3 回答 3

6

只是一个建议:您可以使用多级管道,然后在 Azure Devops Ui 中也非常清楚地表示了这些管道。

阶段有工作,工作有步骤: 在此处输入图像描述

用于此的示例管道 yml:

trigger:
  batch: true
  branches:
    include:
      - "*"


resources:
  containers:
    - container: ubuntu
      image: ubuntu:18.04

stages:
  - stage: STAGE1
    jobs:
     - job: PrintInfoStage1Job1
       container: ubuntu
       steps:
          - script: |
              echo "THIS IS STAGE 1, JOB 1"
            displayName: "JOB 1"
     - job: PrintInfoStage1Job2
       dependsOn: PrintInfoStage1Job1
       container: ubuntu
       steps:
          - script: |
              echo "THIS IS STAGE 1, JOB 2"
            displayName: "JOB 2"

  - stage: STAGE2
    dependsOn: STAGE1
    jobs:
      - job: PrintInfoStage2Job1
        dependsOn: []
        container: ubuntu
        steps:
          - script: |
               echo "THIS IS THE STAGE 2, JOB 1"
            displayName: "JOB 1"

      - job: PrintInfoStage2Job2
        container: ubuntu
        dependsOn: []
        steps:
          - script: |
               echo "THIS IS THE STAGE 2, JOB 2"
            displayName: "JOB 2"

请确保不要错过在用户设置中打开此预览功能的开关。

于 2019-09-27T11:58:05.050 回答
5

在创建一个测试项目并将几个作业添加到它的发布管道中,然后连续运行几次之后,作业的顺序似乎是确定的。也就是说,它们似乎总是按照它们在门户中实际出现的顺序运行。

我做了几次谷歌搜索,但这种行为似乎没有在任何地方记录。所以,我不确定它是否得到保证。但这可能适用于我的情况。

如果有任何官方消息来源确认工作订单得到保证,请发表评论。

于 2019-03-21T20:53:57.250 回答
2

查看已指定的示例,您无需为每个步骤创建不同的作业。每个任务都可以添加到一个作业中。

jobs:
- job: 
  steps:
  - script: echo hello from Deployment Group 1
  - script: echo hello from Deployment Group 2
  - script: echo this is where I would tag the Repo

如果需要,您还可以删除代码中的 Jobs > Job。

我的工作没有按照定义的顺序执行,我也面临着类似的问题。此外,我正在参考其他工作模板。我的印象是每个模板都必须在新工作中。后来,我设法将我的工作分解为任务。

注意事项:

  • 作业在一个独立的代理上运行。如果它只是您想要执行的一系列脚本,您可能不想要。作业本质上包含步骤,这是一组任务。
  • 步骤中的任务是一个接一个地执行的,因此您不必明确提供顺序。
于 2020-03-23T09:22:18.167 回答