Dagster
An orchestration platform for the development, production, and observation of data assets.
**Dagster is a cloud-native data pipeline orchestrator for the whole development lifecycle, with integrated lineage and observability, a declarative programming model, and best-in-class testability.** The project is written primarily in Python, distributed under the Apache License 2.0 license, first published in 2018. It has gained significant community traction with 15,599 stars and 2,152 forks on GitHub. Key topics include: analytics, dagster, data-engineering, data-integration, data-orchestrator.
Dagster is a cloud-native data pipeline orchestrator for the whole development lifecycle, with integrated lineage and observability, a declarative programming model, and best-in-class testability.
It is designed for developing and maintaining data assets, such as tables, data sets, machine learning models, and reports.
With Dagster, you declare—as Python functions—the data assets that you want to build. Dagster then helps you run your functions at the right time and keep your assets up-to-date.
Here is an example of a graph of three assets defined in Python:
pythonimport dagster as dg import pandas as pd from sklearn.linear_model import LinearRegression @dg.asset def country_populations() -> pd.DataFrame: df = pd.read_html("https://tinyurl.com/mry64ebh")[0] df.columns = ["country", "pop2022", "pop2023", "change", "continent", "region"] df["change"] = df["change"].str.rstrip("%").astype("float") return df @dg.asset def continent_change_model(country_populations: pd.DataFrame) -> LinearRegression: data = country_populations.dropna(subset=["change"]) return LinearRegression().fit(pd.get_dummies(data[["continent"]]), data["change"]) @dg.asset def continent_stats(country_populations: pd.DataFrame, continent_change_model: LinearRegression) -> pd.DataFrame: result = country_populations.groupby("continent").sum() result["pop_change_factor"] = continent_change_model.coef_ return result
The graph loaded into Dagster's web UI:
<p align="center"> <img width="100%" alt="An example asset graph as rendered in the Dagster UI" src="https://raw.githubusercontent.com/dagster-io/dagster/master/.github/example-lineage.png"> </p>Dagster is built to be used at every stage of the data development lifecycle - local development, unit tests, integration tests, staging environments, all the way up to production.
Quick Start:
If you're new to Dagster, we recommend checking out the docs or following the hands-on tutorial.
Dagster is available on PyPI and officially supports Python 3.9 through Python 3.14.
bashuv add dagster dagster-webserver dagster-dg-cli
Documentation
You can find the full Dagster documentation here, including the Quickstart guide.
<hr/>Key Features:
<p align="center"> <img width="100%" alt="image" src="https://raw.githubusercontent.com/dagster-io/dagster/master/.github/key-features-cards.svg"> </p>Dagster as a productivity platform
Identify the key assets you need to create using a declarative approach, or you can focus on running basic tasks. Embrace CI/CD best practices from the get-go: build reusable components, spot data quality issues, and flag bugs early.
Dagster as a robust orchestration engine
Put your pipelines into production with a robust multi-tenant, multi-tool engine that scales technically and organizationally.
Dagster as a unified control plane
Maintain control over your data as the complexity scales. Centralize your metadata in one tool with built-in observability, diagnostics, cataloging, and lineage. Spot any issues and identify performance improvement opportunities.
<hr />Master the Modern Data Stack with integrations
Dagster provides a growing library of integrations for today’s most popular data tools. Integrate with the tools you already use, and deploy to your infrastructure.
<br/> <p align="center"> <a target="_blank" href="https://dagster.io/integrations" style="background:none"> <img width="100%" alt="image" src="https://raw.githubusercontent.com/dagster-io/dagster/master/.github/integrations-bar-for-readme.png"> </a> </p>Community
Connect with thousands of other data practitioners building with Dagster. Share knowledge, get help,
and contribute to the open-source project. To see featured material and upcoming events, check out
our Dagster Community page.
Join our community here:
- 🌟 Star us on GitHub
- 📥 Subscribe to our Newsletter
- 🐦 Follow us on Twitter
- 🕴️ Follow us on LinkedIn
- 📺 Subscribe to our YouTube channel
- 📚 Read our blog posts
- 👋 Join us on Slack
- 🗃 Browse Slack archives
- ✏️ Start a GitHub Discussion
Contributing
For details on contributing or running the project for development, check out our contributing
guide.
License
Dagster is Apache 2.0 licensed.
Contributors
Showing top 12 contributors by commit count.