CI/CD in Serverless
If you're a GitHub or GitLab user, you can use our predefined workflows to seamlessly deploy and synchronize your code to Dagster+. You can also use other Git providers or a local Git repository with our dagster-cloud CLI to run your own CI/CD process.
- With GitHub
- With GitLab
- Other Git providers or local development
If you're a GitHub user, with a single click our GitHub app with GitHub Actions can set up a repo containing skeleton code and configuration for you consistent with Dagster+'s best practices. Pushing your code changes to the main
branch will automatically deploy them to your prod
Serverless deployment. Pull requests will spin up ephemeral branch deployments that you can view in the Dagster+ UI for previewing and testing.
If you are importing a Dagster project that's in an existing GitHub repo:
-
The repo will need to allow the Workflow permission for
Read and write permissions
. Workflow permissions settings can be found in GitHub'sSettings
>Actions
>General
>Workflow permissions
. In GitHub Enterprise, these permissions are controlled at the Organization level. -
An initial commit will need to be able to be merged directly to the repo's
main
branch to automatically add the GitHub Actions workflow files. If branch protection rules require changes be done through a pull request, it will prevent the automatic setup from completing.- You can temporarily disable the branch protection rules and then re-enable them after the automatic setup completes.
If you're a GitLab user, with a single click our GitLab app can set up a repo containing skeleton code and CI/CD configuration for you consistent with Dagster+'s best practices. Pushing your code changes to the main
branch will automatically deploy them to your prod
Serverless deployment. Pull requests will spin up ephemeral branch deployments that you can view in the Dagster+ UI for previewing and testing.
If you don't want to use our automated GitHub/GitLab process, we offer the powerful dagster-cloud
command-line interface (CLI) that you can use in another CI environment or locally.
First, create a new project with the Dagster open source CLI.
The example below uses our quickstart_etl example project. For more info about the examples, visit the Dagster GitHub repository.
pip install dagster
dagster project from-example \
--name my-dagster-project \
--example quickstart_etl
If using a different project, ensure that dagster-cloud
is included as a dependency in your setup.py
or requirements.txt
file.
For example, in my-dagster-project/setup.py
:
install_requires=[
"dagster",
"dagster-cloud", # add this line
...
]
Next, install the dagster-cloud
CLI and use its configure
command to authenticate it to your Dagster+ organization.
Note: The CLI requires a recent version of Python 3 and Docker.
pip install dagster-cloud
dagster-cloud configure
You can also configure the dagster-cloud
tool non-interactively; see the CLI docs for more information.
Finally, deploy your project to Dagster+ using the serverless
command:
dagster-cloud serverless deploy-python-executable ./my-dagster-project \
--location-name example \
--package-name quickstart_etl \
--python-version 3.12
Note: Windows users should use the deploy
command instead of deploy-python-executable
.