Skip to main content

Automating Pipelines

Automation is key to building reliable, efficient data pipelines. This guide provides a simplified overview of the main ways to automate processes in Dagster, helping you choose the right method for your needs. You will find links to more detailed guides for each method below.

What you'll learn

  • The different automation options available in Dagster
  • How to implement basic scheduling and event-based triggers
  • Best practices for selecting and using automation methods
Prerequisites

Before continuing, you should be familiar with:

Automation methods overview

Dagster offers several ways to automate pipeline execution:

  1. Schedules - Run jobs at specified times
  2. Sensors - Trigger runs based on events
  3. Asset Sensors - Trigger jobs when specific assets materialize

Schedules

Schedules allow you to run jobs at specified times, like "every Monday at 9 AM" or "daily at midnight." A schedule combines a selection of assets, known as a Job, and a cron expression to define when the job should be run.

To make creating cron expressions easier, you can use an online tool like Crontab Guru.

When to use schedules

  • You need to run jobs at regular intervals
  • You want basic time-based automation

For examples of how to create schedules, see How-To Use Schedules.

For more information about how Schedules work, see About Schedules.

Sensors

Sensors allow you to trigger runs based on events or conditions that you define, like a new file arriving or an external system status change.

You must provide a function that the sensor will use to determine if it should trigger a run.

Like schedules, sensors operate on a selection of assets, known as Jobs and can either start a pipeline through a Run or log a reason for not starting a pipeline using a SkipReason.

When to use sensors

  • You need event-driven automation
  • You want to react to changes in external systems

For more examples of how to create sensors, see the How-To Use Sensors guide.

For more information about how sensors work, see the About Sensors concept page.

Asset sensors

Asset Sensors trigger jobs when specified assets are materialized, allowing you to create dependencies between jobs or code locations.

When to use Asset sensors

  • You need to trigger jobs based on asset materializations
  • You want to create dependencies between different jobs or code locations

For more examples of how to create asset sensors, see the How-To Use Asset Sensors guide.

Declarative automation

TODO: Add content

How to choose the right automation method

Consider these factors when selecting an automation method:

  1. Pipeline Structure: Are you working primarily with assets, ops, or a mix?
  2. Timing Requirements: Do you need regular updates or event-driven processing?
  3. Data Characteristics: Is your data partitioned? Do you need to update historical data?
  4. System Integration: Do you need to react to external events or systems?

Use this table to help guide your decision:

MethodBest ForWorks With
SchedulesRegular, time-based job runsAssets, Ops, Graphs
SensorsEvent-driven automationAssets, Ops, Graphs
Declarative AutomationAsset-centric, condition-based updatesAssets only
Asset SensorsCross-job/location asset dependenciesAssets only

Next steps

  • Learn more about [advanced scheduling patterns] - TODO ADD LINK
  • Explore [complex sensor examples] - TODO ADD LINK
  • Dive into [Declarative Automation best practices] - TODO ADD LINK

By understanding and effectively using these automation methods, you can build more efficient data pipelines that respond to your specific needs and constraints.