156 lines
5.9 KiB
Markdown
156 lines
5.9 KiB
Markdown
---
|
|
stage: Verify
|
|
group: Pipeline Execution
|
|
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
|
|
disqus_identifier: 'https://docs.gitlab.com/ee/user/project/pipelines/schedules.html'
|
|
type: reference, howto
|
|
---
|
|
|
|
# Pipeline schedules **(FREE)**
|
|
|
|
Pipelines are normally run based on certain conditions being met. For example, when a branch is pushed to repository.
|
|
|
|
Pipeline schedules can be used to also run [pipelines](index.md) at specific intervals. For example:
|
|
|
|
- Every month on the 22nd (cron example: `0 0 22 * *`) for a certain branch.
|
|
- Every month on the 2nd Monday (cron example: `0 0 * * 1#2`).
|
|
- Every other Sunday at 0900 hours (cron example: `0 9 * * sun%2`).
|
|
- Once every day (cron example: `0 0 * * *`).
|
|
|
|
Schedule timing is configured with [cron notation](../../topics/cron/index.md).
|
|
You can use any cron value, but scheduled pipelines cannot run more frequently
|
|
than the instance's [maximum frequency for scheduled pipelines](#advanced-configuration).
|
|
|
|
In addition to using the GitLab UI, pipeline schedules can be maintained using the
|
|
[Pipeline schedules API](../../api/pipeline_schedules.md).
|
|
|
|
## Prerequisites
|
|
|
|
In order for a scheduled pipeline to be created successfully:
|
|
|
|
- The schedule owner must have [permissions](../../user/permissions.md) to merge into the target branch.
|
|
- The pipeline configuration must be valid.
|
|
|
|
Otherwise the pipeline is not created.
|
|
|
|
## Configuring pipeline schedules
|
|
|
|
To schedule a pipeline for project:
|
|
|
|
1. Navigate to the project's **CI/CD > Schedules** page.
|
|
1. Click the **New schedule** button.
|
|
1. Fill in the **Schedule a new pipeline** form.
|
|
1. Click the **Save pipeline schedule** button.
|
|
|
|
![New Schedule Form](img/pipeline_schedules_new_form.png)
|
|
|
|
NOTE:
|
|
Pipelines execution [timing is dependent](#advanced-configuration) on Sidekiq's own schedule.
|
|
|
|
In the **Schedules** index page you can see a list of the pipelines that are
|
|
scheduled to run. The next run is automatically calculated by the server GitLab
|
|
is installed on.
|
|
|
|
![Schedules list](img/pipeline_schedules_list.png)
|
|
|
|
### Using variables
|
|
|
|
You can pass any number of arbitrary variables. They are available in
|
|
GitLab CI/CD so that they can be used in your [`.gitlab-ci.yml` file](../../ci/yaml/index.md).
|
|
|
|
![Scheduled pipeline variables](img/pipeline_schedule_variables.png)
|
|
|
|
### Using `rules`
|
|
|
|
To configure a job to be executed only when the pipeline has been
|
|
scheduled, use the [`rules`](../yaml/index.md#rules) keyword.
|
|
|
|
In this example, `make world` runs in scheduled pipelines, and `make build`
|
|
runs in branch and tag pipelines:
|
|
|
|
```yaml
|
|
job:on-schedule:
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
script:
|
|
- make world
|
|
|
|
job:
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "push"
|
|
script:
|
|
- make build
|
|
```
|
|
|
|
### Advanced configuration **(FREE SELF)**
|
|
|
|
Scheduled pipelines can be configured with any [cron value](../../topics/cron/index.md),
|
|
but they do not always run exactly when scheduled. An internal process, called the
|
|
_pipeline schedule worker_, queues all the scheduled pipelines, but does not
|
|
run continuously. The worker runs on its own schedule, and scheduled pipelines that
|
|
are ready to start are only queued the next time the worker runs. Scheduled pipelines
|
|
can't run more frequently than the worker.
|
|
|
|
The default frequency of the pipeline schedule worker is `3-59/10 * * * *` (every ten minutes,
|
|
starting with `0:03`, `0:13`, `0:23`, and so on). The default frequency for GitLab.com
|
|
is listed in the [GitLab.com settings](../../user/gitlab_com/index.md#gitlab-cicd).
|
|
|
|
To change the frequency of the pipeline schedule worker:
|
|
|
|
1. Edit the `gitlab_rails['pipeline_schedule_worker_cron']` value in your instance's `gitlab.rb` file.
|
|
1. [Reconfigure GitLab](../../administration/restart_gitlab.md#omnibus-gitlab-reconfigure) for the changes to take effect.
|
|
|
|
For example, to set the maximum frequency of pipelines to twice a day, set `pipeline_schedule_worker_cron`
|
|
to a cron value of `0 */12 * * *` (`00:00` and `12:00` every day).
|
|
|
|
## Working with scheduled pipelines
|
|
|
|
After configuration, GitLab supports many functions for working with scheduled pipelines.
|
|
|
|
### Running manually
|
|
|
|
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/15700) in GitLab 10.4.
|
|
|
|
To trigger a pipeline schedule manually, click the "Play" button:
|
|
|
|
![Play Pipeline Schedule](img/pipeline_schedule_play.png)
|
|
|
|
This schedules a background job to run the pipeline schedule. A flash
|
|
message provides a link to the CI/CD Pipeline index page.
|
|
|
|
NOTE:
|
|
To help avoid abuse, users are rate limited to triggering a pipeline once per
|
|
minute.
|
|
|
|
### Taking ownership
|
|
|
|
Pipelines are executed as a user, who owns a schedule. This influences what projects and other resources the pipeline has access to.
|
|
|
|
If a user does not own a pipeline, you can take ownership by clicking the **Take ownership** button.
|
|
The next time a pipeline is scheduled, your credentials are used.
|
|
|
|
![Schedules list](img/pipeline_schedules_ownership.png)
|
|
|
|
If the owner of a pipeline schedule cannot create
|
|
pipelines on the target branch, the schedule stops creating new
|
|
pipelines.
|
|
|
|
This can happen if, for example:
|
|
|
|
- The owner is blocked or removed from the project.
|
|
- The target branch or tag is protected.
|
|
|
|
In this case, someone with sufficient privileges must take ownership of the
|
|
schedule.
|
|
|
|
<!-- ## Troubleshooting
|
|
|
|
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
|
|
one might have when setting this up, or when something is changed, or on upgrading, it's
|
|
important to describe those, too. Think of things that may go wrong and include them here.
|
|
This is important to minimize requests for support, and to avoid doc comments with
|
|
questions that you know someone might ask.
|
|
|
|
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
|
|
If you have none to add when creating a doc, leave this section in place
|
|
but commented out to help encourage others to add to it in the future. -->
|