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:
- Schedules - Run jobs at specified times
- Sensors - Trigger runs based on events
- 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:
- Pipeline Structure: Are you working primarily with assets, ops, or a mix?
- Timing Requirements: Do you need regular updates or event-driven processing?
- Data Characteristics: Is your data partitioned? Do you need to update historical data?
- System Integration: Do you need to react to external events or systems?
Use this table to help guide your decision:
Method | Best For | Works With |
---|---|---|
Schedules | Regular, time-based job runs | Assets, Ops, Graphs |
Sensors | Event-driven automation | Assets, Ops, Graphs |
Declarative Automation | Asset-centric, condition-based updates | Assets only |
Asset Sensors | Cross-job/location asset dependencies | Assets 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.