Azure Devops YAML管道-如何重复执行任务

时间:2020-04-23 22:44:31

标签: azure-devops azure-pipelines azure-devops-yaml

在我的YAML管道中,我有一个部署工作:

- stage: deployment_to_development
  jobs:
  - deployment: deployment_to_development
    displayName: Deploy to Development
    environment: Development
    variables:
    - template: migrate-vars.yml
    strategy:
      runOnce:
        deploy:
          steps:
          - template: migrate-data.yml

部署模板是一个简单的DbUp任务:

steps:
  - task: UpdateDatabaseWithDbUp@2
    displayName: Migrate data
    inputs:
      ConnectionString: 'Data Source=$(DatabaseServer);Initial Catalog=$(DatabaseName);Integrated Security=SSPI'
      ScriptPath: '$(Pipeline.Workspace)\data-migrations'
      JournalSchemaName: dbo
      JournalTableName: _SchemaVersions
      LogScriptOutput: true
      IncludeSubfolders: true
      Order: FolderStructure
      TransactionStrategy: SingleTransaction

变量模板定义服务器和数据库名称:

variables:
   DatabaseServer: 'server'
   DatabaseName: 'dbName'
   Instances: '_1,_2'

这对于单个数据库都可以正常工作。但是,我希望对Instances变量中定义的每个实例(即,名为dbName_1,dbName_2的数据库)重复执行该任务。这个看似简单的壮举却很难。

我尝试将实例作为参数数组传递并使用

进行迭代
parameters:
  param: []

steps:
  - ${{each p in parameters.param}}:

,但未在任务中评估'p'变量。 还有许多徒劳的尝试。我必须在这里遗漏一些非常明显的东西。什么事?

1 个答案:

答案 0 :(得分:4)

我无法测试UpdateDatabaseWithDbUp@2,但是我有什么解释了您如何实现目标的。首先定义templeate.yaml

parameters:
- name: 'instances'
  type: object
  default: {}
- name: 'server'
  type: string
  default: ''

steps:
- ${{ each instance in parameters.instances }}:
  - script: echo ${{ parameters.server }}:${{ instance }}

然后在您的版本中重复使用此模板:

steps:
- template: template.yaml
  parameters:
    instances: 
    - test1
    - test2
    server: someServer

结果如下:

Azure DevOps Logs