2020-01-14 07:07:41 -05:00
---
2020-05-29 14:08:26 -04:00
stage: Verify
group: Continuous Integration
2020-11-26 01:09:20 -05:00
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2020-01-14 07:07:41 -05:00
type: reference
---
# Parent-child pipelines
2020-05-20 23:08:00 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/16094) in GitLab 12.7.
2020-01-14 07:07:41 -05:00
As pipelines grow more complex, a few related problems start to emerge:
- The staged structure, where all steps in a stage must be completed before the first
job in next stage begins, causes arbitrary waits, slowing things down.
- Configuration for the single global pipeline becomes very long and complicated,
making it hard to manage.
- Imports with [`include` ](yaml/README.md#include ) increase the complexity of the configuration, and create the potential
for namespace collisions where jobs are unintentionally duplicated.
- Pipeline UX can become unwieldy with so many jobs and stages to work with.
Additionally, sometimes the behavior of a pipeline needs to be more dynamic. The ability
to choose to start sub-pipelines (or not) is a powerful ability, especially if the
YAML is dynamically generated.
![Parent pipeline graph expanded ](img/parent_pipeline_graph_expanded_v12_6.png )
Similarly to [multi-project pipelines ](multi_project_pipelines.md ), a pipeline can trigger a
set of concurrently running child pipelines, but within the same project:
- Child pipelines still execute each of their jobs according to a stage sequence, but
would be free to continue forward through their stages without waiting for unrelated
jobs in the parent pipeline to finish.
- The configuration is split up into smaller child pipeline configurations, which are
easier to understand. This reduces the cognitive load to understand the overall configuration.
- Imports are done at the child pipeline level, reducing the likelihood of collisions.
2020-01-20 01:08:35 -05:00
- Each pipeline has only relevant steps, making it easier to understand what's going on.
2020-01-14 07:07:41 -05:00
2020-03-26 23:07:56 -04:00
Child pipelines work well with other GitLab CI/CD features:
2020-01-14 07:07:41 -05:00
- Use [`only: changes` ](yaml/README.md#onlychangesexceptchanges ) to trigger pipelines only when
certain files change. This is useful for monorepos, for example.
- Since the parent pipeline in `.gitlab-ci.yml` and the child pipeline run as normal
pipelines, they can have their own behaviors and sequencing in relation to triggers.
2020-08-13 14:10:36 -04:00
See the [`trigger:` ](yaml/README.md#trigger ) keyword documentation for full details on how to
include the child pipeline configuration.
2020-01-14 07:07:41 -05:00
2020-04-23 20:09:28 -04:00
< i class = "fa fa-youtube-play youtube" aria-hidden = "true" > < / i >
For an overview, see [Parent-Child Pipelines feature demo ](https://youtu.be/n8KpBSqZNbk ).
2020-01-14 07:07:41 -05:00
## Examples
2020-02-11 01:09:46 -05:00
The simplest case is [triggering a child pipeline ](yaml/README.md#trigger ) using a
2020-11-18 13:09:08 -05:00
local YAML file to define the pipeline configuration. In this case, the parent pipeline
triggers the child pipeline, and continues without waiting:
2020-01-14 07:07:41 -05:00
```yaml
microservice_a:
trigger:
include: path/to/microservice_a.yml
```
You can include multiple files when composing a child pipeline:
```yaml
microservice_a:
trigger:
include:
- local: path/to/microservice_a.yml
2020-09-22 14:09:54 -04:00
- template: Security/SAST.gitlab-ci.yml
2020-01-14 07:07:41 -05:00
```
2020-10-07 14:08:34 -04:00
In [GitLab 13.5 ](https://gitlab.com/gitlab-org/gitlab/-/issues/205157 ) and later,
you can use [`include:file` ](yaml/README.md#includefile ) to trigger child pipelines
with a configuration file in a different project:
```yaml
microservice_a:
trigger:
include:
- project: 'my-group/my-pipeline-library'
file: 'path/to/ci-config.yml'
```
2020-10-14 14:08:47 -04:00
The maximum number of entries that are accepted for `trigger:include:` is three.
2020-01-14 07:07:41 -05:00
Similar to [multi-project pipelines ](multi_project_pipelines.md#mirroring-status-from-triggered-pipeline ),
we can set the parent pipeline to depend on the status of the child pipeline upon completion:
```yaml
microservice_a:
trigger:
include:
- local: path/to/microservice_a.yml
2020-09-22 14:09:54 -04:00
- template: Security/SAST.gitlab-ci.yml
2020-01-14 07:07:41 -05:00
strategy: depend
```
2020-02-21 04:09:01 -05:00
## Merge Request child pipelines
To trigger a child pipeline as a [Merge Request Pipeline ](merge_request_pipelines/index.md ) we need to:
- Set the trigger job to run on merge requests:
```yaml
# parent .gitlab-ci.yml
microservice_a:
trigger:
include: path/to/microservice_a.yml
rules:
- if: $CI_MERGE_REQUEST_ID
```
- Configure the child pipeline by either:
- Setting all jobs in the child pipeline to evaluate in the context of a merge request:
```yaml
# child path/to/microservice_a.yml
workflow:
rules:
- if: $CI_MERGE_REQUEST_ID
job1:
script: ...
job2:
script: ...
```
- Alternatively, setting the rule per job. For example, to create only `job1` in
the context of merge request pipelines:
```yaml
# child path/to/microservice_a.yml
job1:
script: ...
rules:
- if: $CI_MERGE_REQUEST_ID
job2:
script: ...
```
2020-03-16 11:09:27 -04:00
## Dynamic child pipelines
2020-05-20 23:08:00 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/35632) in GitLab 12.9.
2020-03-16 11:09:27 -04:00
Instead of running a child pipeline from a static YAML file, you can define a job that runs
your own script to generate a YAML file, which is then [used to trigger a child pipeline ](yaml/README.md#trigger-child-pipeline-with-generated-configuration-file ).
This technique can be very powerful in generating pipelines targeting content that changed or to
build a matrix of targets and architectures.
2020-04-23 20:09:28 -04:00
< i class = "fa fa-youtube-play youtube" aria-hidden = "true" > < / i >
For an overview, see [Create child pipelines using dynamically generated configurations ](https://youtu.be/nMdfus2JWHM ).
2021-01-29 16:09:34 -05:00
<!-- vale gitlab.Spelling = NO -->
We also have an example project using
[Dynamic Child Pipelines with Jsonnet ](https://gitlab.com/gitlab-org/project-templates/jsonnet )
which shows how to use a data templating language to generate your `.gitlab-ci.yml` at runtime. You could use a similar process for other templating languages like [Dhall ](https://dhall-lang.org/ ) or [`ytt` ](https://get-ytt.io/ ).
<!-- vale gitlab.Spelling = NO -->
2020-07-22 05:09:38 -04:00
2020-11-18 04:09:02 -05:00
The artifact path is parsed by GitLab, not the runner, so the path must match the
syntax for the OS running GitLab. If GitLab is running on Linux but using a Windows
runner for testing, the path separator for the trigger job would be `/` . Other CI/CD
configuration for jobs, like scripts, that use the Windows runner would use `\` .
2020-04-09 11:09:29 -04:00
In GitLab 12.9, the child pipeline could fail to be created in certain cases, causing the parent pipeline to fail.
This is [resolved in GitLab 12.10 ](https://gitlab.com/gitlab-org/gitlab/-/issues/209070 ).
2020-09-17 05:09:32 -04:00
## Nested child pipelines
2020-01-14 07:07:41 -05:00
2020-09-17 05:09:32 -04:00
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29651) in GitLab 13.4.
2020-10-16 11:08:46 -04:00
> - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/243747) in GitLab 13.5.
2020-09-08 11:08:41 -04:00
2020-09-17 05:09:32 -04:00
Parent and child pipelines were introduced with a maximum depth of one level of child
pipelines, which was later increased to two. A parent pipeline can trigger many child
pipelines, and these child pipelines can trigger their own child pipelines. It's not
possible to trigger another level of child pipelines.
2021-02-11 04:09:18 -05:00
< i class = "fa fa-youtube-play youtube" aria-hidden = "true" > < / i >
For an overview, see [Nested Dynamic Pipelines ](https://youtu.be/C5j3ju9je2M ).
2021-02-16 13:09:24 -05:00
## Pass CI/CD variables to a child pipeline
2020-10-13 08:08:41 -04:00
2021-02-16 13:09:24 -05:00
You can [pass CI/CD variables to a downstream pipeline ](multi_project_pipelines.md#passing-cicd-variables-to-a-downstream-pipeline )
2020-12-04 07:09:39 -05:00
the same way as for multi-project pipelines.