摸索并行矩阵

Cod*_*lla 7 gitlab-ci

这似乎是对 GitLab 13.3 中新的并行矩阵功能的误用(https://docs.gitlab.com/ee/ci/yaml/#parallel-matrix-jobs

我有一组服务的并行作业集合:build(docker image), test, release, delete.... 并且创建了代码库,以便每个并行服务都位于单独的子目录中。

这样我就可以有一个通用模板:

variables:
  IMAGE_NAME: $CI_REGISTRY_IMAGE/$LOCATION

.build-template:
  script:
    - docker build --tag $IMAGE_NAME:$CI_PIPELINE_ID-$CI_COMMIT_REF_SLUG --tag $IMAGE_NAME:latest $LOCATION
  stage: build
  when: manual
Run Code Online (Sandbox Code Playgroud)

然后多个构建作业:

build-alpha:
  extends: .build-template
  variables:
    LOCATION: alpha

build-beta:
  extends: .build-template
  variables:
    LOCATION: beta
Run Code Online (Sandbox Code Playgroud)

....并根据需要重复。

test然后,我可以对、release和jobs执行相同的操作delete:一个通用模板,仅使用一个变量来区分服务。

矩阵来救援?

在我看来

variables:
  IMAGE_NAME: $CI_REGISTRY_IMAGE/$NOTEBOOK

build-services:
  parallel:
    matrix:
      - LOCATION: alpha
      - LOCATION: beta
  script:
    - docker build --tag $IMAGE_NAME:$CI_PIPELINE_ID-$CI_COMMIT_REF_SLUG --tag $IMAGE_NAME:latest $LOCATION
  stage: build
  when: manual
Run Code Online (Sandbox Code Playgroud)

将是这种形式的理想matrix候选者......但显然matrix需要两个变量。

有没有人对这个多并行作业问题有一个好的解决方案?

Von*_*onC 4

\n

将是这种矩阵形式的理想候选者......但显然矩阵需要两个变量。

\n
\n

不再。

\n

请参阅GitLab 13.5(2020 年 10 月)

\n
\n

允许一维并行矩阵

\n

以前,parallel: matrix并行运行作业矩阵的关键字仅接受二维矩阵数组。如果您想为某些作业指定自己的值数组,这会受到限制。

\n

在此版本中,您现在可以更加灵活地以最适合您的开发工作流程的方式运行作业。
\n您可以在一维数组中运行并行作业矩阵,从而使管道配置更加简单。感谢Turo Soisenniemi做出的惊人贡献!

\n

Here\xe2\x80\x99是实践中的一个基本示例,它将针对不同版本的 Node.js 运行 3 个测试作业,但您可以将此方法应用于您的特定用例,并轻松地在管道中添加或删除作业:

\n

https://about.gitlab.com/images/13_5/simple-parallel-matrices-example.png -- 一维矩阵示例

\n

请参阅文档问题

\n
\n
\n

以及GitLab 13.10(2021 年 3 月)

\n
\n

将“并行:矩阵”与触发器作业一起使用

\n

您可以使用parallel: matrix关键字并行运行作业多次,并为作业的每个实例使用不同的变量值。

\n

不幸的是,您无法将其与触发器作业一起使用。

\n

在此版本中,我们扩展了并行矩阵功能以支持触发器作业,因此您现在可以使用每个下游管道的不同变量值并行运行多个下游管道(子管道或多项目管道)。
\n这使您可以配置更快、更灵活的 CI/CD 管道。

\n

https://about.gitlab.com/images/13_10/parallel.png - 将“parallel:matrix”与触发器作业一起使用

\n

请参阅文档问题

\n
\n
\n

文档:“运行并行触发作业矩阵

\n