Scheduled Pipelines
Overview
Scheduled pipelines allow you to trigger pipelines periodically based on a schedule.
Since the scheduled run is based on pipelines, scheduled pipelines have all the features that come with using pipelines:
- Control the actor associated with the pipeline, which can enable the use of restricted contexts.
- Use dynamic config via setup workflows.
- Modify the schedule without having to edit .circleci/config.yml.
- Take advantage of auto-cancelling.
- Specify pipeline parameters associated with a schedule.
- Manage common schedules, e.g. across workflows.
Scheduled pipelines are configured through the API, or through the project settings in the CircleCI application.
Get started with scheduled pipelines in CircleCI
You have the option of setting up scheduled pipelines from scratch, or you can migrate existing scheduled workflows to scheduled pipelines.
Start from scratch
Use the API
If your project has no scheduled workflows and you would like to try out scheduled pipelines:
- Have your CCI token ready, or create a new token by following these steps.
- Create a new schedule using the API. For example:
curl --location --request POST 'https://circleci.com/api/v2/project/<project-slug>/schedule' \
--header 'circle-token: <your-cci-token>' \
--header 'Content-Type: application/json' \
--data-raw '{
    "name": "my schedule name",
    "description": "some description",
    "attribution-actor": "system",
    "parameters": {
      "branch": "main"
      <additional pipeline parameters can be added here>
    },
    "timetable": {
        "per-hour": 3,
        "hours-of-day": [1,15],
        "days-of-week": ["MON", "WED"]
    }
}'
For additional information, refer to the Schedule section under the API v2 docs.
Use project settings
- In the CircleCI application, navigate to Projects in the sidebar, then click the ellipsis (…) next to your project. You can also find the Project Settings button on each project’s landing page.
- Navigate to Triggers.
- To create a new schedule, click Add Scheduled Trigger.
- Define the new schedule’s name, timetable, pipeline parameters, and attribution actor (i.e. user associated with the schedule), then save the trigger.
Migrate scheduled workflows to scheduled pipelines
The current method for scheduling work on your projects is to use the scheduled workflows feature. This feature has some limitations, so consider migrating your scheduled workflows to the scheduled pipelines feature. Some limitations of scheduled workflows are:
- Cannot control the actor, so scheduled workflows can’t use restricted contexts.
- Cannot control the interaction with auto-cancelling of pipelines.
- Cannot use scheduled workflows together with dynamic config without complex workarounds.
- Cannot change or cancel scheduled workflows on a branch without triggering a pipeline.
- Cannot kick off test runs for scheduled workflows without changing the schedule.
- Cannot restrict scheduled workflows from PR branches if you want the workflow to run on webhooks.
To migrate from scheduled workflows to scheduled pipelines, follow the steps below:
-  Find the scheduled trigger in your project’s .circleci/config.ymlFor example, it might look like:daily-run-workflow: triggers: - schedule: # Every day, 0421Z. cron: "21 4 * * *" filters: branches: only: - main jobs: - test - build
- Interpret the frequency your trigger needs to run from the cron expression.
- Use the same step from the Start from scratch section above to create the schedule via the API or project settings.
- In the config file, remove the triggerssection, so that it resembles a standard workflow.daily-run-workflow: jobs: - test - build
Add workflows filtering
As a scheduled pipeline is essentially a triggered pipeline, it will run every workflow in the config.
One way to implement workflows filtering is by using the pipeline values. For example:
daily-run-workflow:
  when:
    and:
      - equal: [ scheduled_pipeline, << pipeline.trigger_source >> ]
      - equal: [ "my schedule name", << pipeline.schedule.name >> ]
  jobs:
    - test
    - build
Note that in the above example, the second equal under when is not strictly necessary. The pipeline.schedule.name is an available pipeline value when the pipeline is triggered by a schedule.
You may also add filtering for workflows that should NOT run when a schedule triggers:
daily-run-workflow:
  when:
    and:
      - equal: [ scheduled_pipeline, << pipeline.trigger_source >> ]
      - equal: [ "my schedule name", << pipeline.schedule.name >> ]
  jobs:
    - test
    - build
other-workflow:
  when:
    not:
      equal: [ scheduled_pipeline, << pipeline.trigger_source >> ]
  jobs:
   - build
   - deploy
FAQs
Q: How do I find the schedules that I have created?
A: As scheduled pipelines are stored directly in CircleCI, there is a UUID associated with each schedule. You can view schedules that you have created on the Triggers page of the project settings. You can also list all the schedules under a single project:
curl --location --request GET 'https://circleci.com/api/v2/project/<project-slug>/schedule' \
--header 'circle-token: <PERSONAL_API_KEY>'
project-slug takes the form of vcs-slug/org-name/repo-name, e.g. gh/CircleCI-Public/api-preview-docs.
Q: Why is my scheduled pipeline not running?
A: There could be a few possible reasons:
- Is the actor who is set for the scheduled pipelines still part of the organization?
- Is the branch set for the schedule deleted?
- Is your GitHub organization using SAML protection? SAML tokens expire often, which can cause requests to GitHub to fail.
Q: Why did my scheduled pipeline run later than expected?
A: There is a nuanced difference in the scheduling expression with Scheduled Pipelines, compared to the Cron expression.
For example, when you express the schedule as 1 per-hour for 08:00 UTC, the scheduled pipeline will run once within the 08:00 to 09:00 UTC window. Note that it does not mean that it will run at 08:00 UTC exactly.
However, subsequent runs of the scheduled pipeline will always be run on the same time as its previous run. In other words, if a previous scheduled pipeline ran at 08:11 UTC, the next runs should also be at 08:11 UTC.
Q: Do you support regex?
A: Not currently. Scheduled pipelines require highly deterministic inputs such as a commit SHA, branch, or tag (fully qualified, no regexes) included in the webhook, API call, or schedule.
Help make this document better
This guide, as well as the rest of our docs, are open source and available on GitHub. We welcome your contributions.
- Suggest an edit to this page (please read the contributing guide first).
- To report a problem in the documentation, or to submit feedback and comments, please open an issue on GitHub.
- CircleCI is always seeking ways to improve your experience with our platform. If you would like to share feedback, please join our research community.
Need support?
Our support engineers are available to help with service issues, billing, or account related questions, and can help troubleshoot build configurations. Contact our support engineers by opening a ticket.
You can also visit our support site to find support articles, community forums, and training resources.

CircleCI Documentation by CircleCI is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.
