/terraform-azurerm-aci-dagster

A terraform module that deploys Dagster to Azure.

Primary LanguageHCLMIT LicenseMIT

Maintained by dataroots Terraform 0.13

Terraform module Dagster on Azure

This is a module for Terraform that deploys Dagster in Azure.

Setup

The dagster terraform module will create the following services:

  • Azure Resource Group
  • Azure Storage Account
  • Azure File Share containing dagster configuration files
  • Azure PostgreSQL server/database
  • An Azure App Service:
    • running the Dagit UI and Dagster Daemon containers

Average cost of the minimal setup with Azure database: ~50$/month

Intend

The Dagster setup provided with this module is intended to be used as an orchestration tool. The setup will allow you to manage your data pipelines, runs, schedules etc...

Usage

module "dagster" {
    source = "datarootsio/aci-dagster/azure"

    resource_prefix = "my-awesome-company"
    resource_suffix = "env"
    db_password = "super-secret-pass"
}

Adding new pipelines to Dagster

To add new pipelines to Dagster:

  • Add the new pipeline to the 'workspace.yaml' configuration file.
load_from:
  - python_file:
      relative_path: new_pipeline.py
      working_directory: /path/to/mounted/volume
  • Update the created Azure Fileshare by adding the new pipeline and the updated 'workspace.yaml' file. This way Dagit and the Dagster Daemon have access to the new pipeline, which will show up in the Dagit UI.

Security

This module supports HTTPS however RBAC is not supported (yet?) by Dagster. Therefore, this module results in Dagit being publicly available. It is important to note that the user should implement and manage authentication themselves, for example by implementing SSO.

Requirements

Name Version
azurerm >=2.56.0

Providers

Name Version
azurerm >=2.56.0

Inputs

Name Description Type Default Required
azurerm_version The desired azurerm version to create the module with string "=2.56.0" no
charset Specifies the Charset for the PostgreSQL Database string "UTF8" no
container_start_limit Limit (in seconds) on the start up time of the containers number 1800 no
dagit_port_number The public port for the running dagit container number 8080 no
dagster_container_home n/a string "/opt" no
dagster_file The dagster instance configuration file string "dagster.yaml" no
db_collation Collation type of the SQL database string "English_United States.1252" no
db_password The password associated with the server login string "" no
db_username The administrator login name for the SQL server string "" no
location The location of the resource group that will be created in which all services are created string "West Europe" no
resource_prefix Prefix that will be given to every resource name string "ps" no
resource_suffix Suffix that will be given to every resource name string "sp" no
server_port n/a number "5432" no
server_version The version of the created SQL server string "11" no
service_plan_size n/a string "S1" no
service_plan_tier n/a string "Standard" no
sku_name Billing information related properties of a server string "GP_Gen5_2" no
storage_account_replication The replication strategy for the created storage account string "LRS" no
storage_account_tier The performance tier for the created storage account string "Standard" no
tags Custom tag that will be added to every resource for easier management map(string)
{
"Name": "terraform-azure-dagster"
}
no
workspace_file The workspace configuration file string "workspace.yaml" no

Outputs

Name Description
dagster_appservice_url The url of the running app service. This url can be used to access the Dagit webserver

Makefile Targets

Available targets:

  tools                             Pull Go and Terraform dependencies
  fmt                               Format Go and Terraform code
  lint/lint-tf/lint-go              Lint Go and Terraform code
  test/testverbose                  Run tests

Contributing

Contributions to this repository are very welcome! Found a bug or do you have a suggestion? Please open an issue. Do you know how to fix it? Pull requests are welcome as well! To get you started faster, a Makefile is provided.

Make sure to install Terraform, Go (for automated testing) and Make (optional, if you want to use the Makefile) on your computer. Install tflint to be able to run the linting.

  • Setup tools & dependencies: make tools
  • Format your code: make fmt
  • Linting: make lint
  • Run tests: make test (or go test -timeout 2h ./... without Make)

Make sure you branch from the 'open-pr-here' branch, and submit a PR back to the 'open-pr-here' branch.

License

MIT license. Please see LICENSE for details.