Skip to content

Latest commit

 

History

History
258 lines (205 loc) · 10.1 KB

README.md

File metadata and controls

258 lines (205 loc) · 10.1 KB

Features

  • Composable Stacks

    • Smaller, composable state files that can be deployed isolated and in parallel
    • Smaller Blast radius
    • Ownership model / governance
    • Natural ordering using the filesystem / filetree hierarchy
    • Supports Terraform, OpenTofu and Terragrunt
    • Supports all patterns: workspaces, partial backend, tfenv, blabla
  • Code Generation

    • Reduce code maintenance DRY
    • Declare and reuse data throughout the stack hierarchy (manage module versions, provider versions, etc - programmatically)
  • Zero-Config Orchestration

    • Zero Config Orchestration using implicit configurations
    • Unlimited concurrency at no additional costs
    • Fast run-times and parallelization via change detection
    • Custom workflows
  • Observability & Visibility

    • Pull Requests & Deployment Logs (especially when using parallelization)
  • Detect and remediate security vulnerabilities

  • Drift Detection and Remediation Reconciliation

  • Incident Management & Alerts

    • Slack Bot Integration to notify individuals and teams for failed deployments and drift, assign and manage those events as incidents
  • Asset Management / CMDB

    • Understand all managed infrastructure among all teams, all repositories, all cloud accounts
    • Detect CIS Benchmark violations

Benefits

  • Better Collaboration (e.g. though alerts)
  • No waiting times (e.g. though parallelization and change detection)
  • No duplication of your CI/CD stack

USPs

  • Highly secure - Doesn't require access to cloud accounts or state
  • Highly performant (unlimited concurrency, reuse your CI/CD, change detection)
  • Supports workspaces, directories, terragrunt, tfenv, partial backend configuration and all other
  • 0 migration effort, any existing infrastructure can be onboarded
  • 0 lock-in, can be offboarded at any point of time without breaking your environment

Examples

  • Using outputs sharing via code generation 01_exmaple_outputs
  • Using data sources 02_exmaple_data_sources (this is simpler and doesn't require any code generation)

Start from scratch

  • Clone the repository https://github.com/ned1313/env0-environment-outputs
  • Login to your azure account az login and select a subscription
  • Run terramate create –all-terraform to onboard Terramate stacks to root modules
  • Give the stacks a meaningful description and name in the stacks.tm.hcl files, this will later help you to identify stacks in Terramate Cloud properly
  • Create a directory .tf_plugin_cache_dir at the root level for provider caching (mkdir ..tf_plugin_cache_dir && touch .tf_plugin_cache_dir/.gitkeep)
  • Register for a Terramate Cloud account at https://cloud.terramate.io and create an organization
  • Login with the CLI using terramate cloud login.
  • Create terramate.tm.hcl as mentioned below to configure the project
  • Start deploying / syncing operations

Start with Examples

  • Clone the fork/updated code https://github.com/soerenmartius/terramate-azure-demo
  • Login to your azure account az login and select a subscription
  • See all stacks in your terramate list (can also be used with filters such as change detection and tags terramate list --changed --tags kubernetes,terraform)
  • Accept invitation to Terramate Cloud ACcounts
  • Login with the CLI using terramate cloud login.
  • Create terramate.tm.hcl to configure your Terramate project (Terramate uses HCL for configuration, but yml and env variables are supported also). Suffix .tm.hcl and .tm are accepted. All Terramate configuration files in the same directory are merged, similar to what Terraform does with .tf files.
  • terramate fmt will format all your Terraform configuration files recursively throughout the hierachy
# terramate.tm.hcl
terramate {
  required_version = ">= 0.11.1"

  # required_version_allow_prereleases = true

  config {
    # Optionally disable safe guards
    # Learn more: https://terramate.io/docs/cli/orchestration/safeguards
    # disable_safeguards = [
    #   "git-untracked",
    #   "git-uncommitted",
    #   "git-out-of-sync",
    #   "outdated-code",
    # ]

    # Configure the namespace of your Terramate Cloud organization
    cloud {
      organization = "<TERRAMATE-CLOUD-ORGANIZATION-NAMESPACE>"
    }

    # git {
    #   default_remote = "origin"
    #   default_branch = "main"
    # }

    run {
      env {
        TF_PLUGIN_CACHE_DIR = "${terramate.root.path.fs.absolute}/.tf_plugin_cache_dir"
      }
    }

    # Enable Experiments
    experiments = [
      "scripts",
      "outputs-sharing",
    ]
  }
}

Stacks Basics

Stacks are a at the most basic form just a directory with a stack.tm.hcl. They are used to group infrastructure code, configuratin and state (often managed remote) and can be executed in an isolated manner.

Stacks can either be nested to work with an implicit order of execution, e.g.

network/
  aks/
  flux/

Or by using before and after to configure the explicit order of execution

Orchestration Basics

When running commands such as terramate run, Terramate creates a DAG of stack that can be filted with e.g. change detection or tags.

  • Understand the run order with terramate list –run-order (also accepts filters)
  • Understand what stacks contain changes in the current PR, branch or range of commits terramate list --changed
  • Run commands in the DAG of stacks using terramate run -- <CMD>

Example: 01_example_outputs Using Terraform and outputs sharing via code generation

In example_outputs/, we are using Terramate code generation to generate output dependencies among stacks using the outputs sharing feature in the CLI. This will generate outputs and variables allowing users to stay in a native environment.

  • Run terramate generate to run all code generation (variables and outputs in this example, I checked those in to the repository already)
  • Run terramate run -X -- terraform init to download dependencies
  • Run a plan in all stacks with enabled output sharing and mocking
    terramate run \
      -X \
      -C 01_example_outputs \
      --enable-sharing \
      --mock-on-fail \
      -- \
      terraform plan -out out.tfplan
  • Deploy the infrastructure sequentially (network -> aks -> flux)
    terramate run \
      -X \
      -C 01_example_outputs \
      --enable-sharing \
      --mock-on-fail \
      --sync-deployment \
      --terraform-plan-file=out.tfplan \
      -- \
      terraform apply -input=false -auto-approve -lock-timeout=5m out.tfplan

This will make the deployment observability for all stacks available at https://cloud.terramate.io/o/sm-azure-demo/deployments/

  • understand what plans have been applied

  • who deployed when

  • health checks are optional drift detection checks that can be run and synced after each deployment to understand if a stack has drifted right away. This is especially helpful when looking at partially applied plans as it helps to understand the desired plan vs what was actually applied

  • Run a drift check and sync to Terramate Cloud (can also run in parallel in stacks that aren't dependent on each other using the --parallel <THREADS> flag)

    terramate run \
     -X \
     -C 01_example_outputs \
     --enable-sharing \
     --mock-on-fail \
     --sync-drift-status \
     --terraform-plan-file drift.tfplan \
     --continue-on-error \
     -- \
     terraform plan -out drift.tfplan -input=false -detailed-exitcode -lock=false
  • Dashboard now shows an overview of all stacks: https://cloud.terramate.io/o/sm-azure-demo/dashboard

  • Stacks list is available at https://cloud.terramate.io/o/sm-azure-demo/stacks?page=1 (see how the id, name and description are synced from CLI, This also works with optional configuration parameters such as tags)

  • E.g. look at what resources a stack manages: https://cloud.terramate.io/o/sm-azure-demo/stacks/5498143?page=1#resources

  • Resource browser, CIS Policy checks, etc. is available at https://cloud.terramate.io/o/sm-azure-demo/resources?page=1

This works because Terramate CLI is syncing sanitized plans to Terramate Cloud. Plans are sanitized on the client side - no credentials or sensitive values are synced to Terramate Cloud.

  • Query all drifted stack with terramate list --status drifted

  • Reconcile drift with terramate run --status drifted -- terraform apply (can be used in workflows to automatically reconcile drift after drift detection in combination with tags to decide what stacks should be reconciled automatically, e.g. terramate run --status drifted --tags reconcile -- terraform apply)

  • Destroy all infrastructure

    terramate run \
      -X \
      -C 01_example_outputs \
      --reverse \
      --enable-sharing \
      --mock-on-fail \
      -- \
      terraform destroy -auto-approve

Example: 02_example_data_sources Using OpenTofu and data sources and implicit order of executing (by sorting using the file tree hierachy / nesting)

Hierarchy (nested, implicit ordering):

network/
  aks/
    fllux/
#    fllux2/ # if we would have N stacks on the same level they could execute in parallel
  • no before and after required because stacks are nested

  • See run order with terramate list --run-order

  • Install all dependencies terramate run -X -C 02_example_data_sources -- tofu init

  • Create a plan in all stacks

    terramate run \
      -X \
      -C 02_example_data_sources \
      -- \
      tofu plan -out out.tfplan
  • Deploy the infrastructure sequentially (network -> aks -> flux)

    terramate run \
      -X \
      -C 02_example_data_sources \
      --sync-deployment \
      --tofu-plan-file=out.tfplan \
      -- \
      tofu apply -input=false -auto-approve -lock-timeout=5m out.tfplan

Worklows

In .github

  • Preview workflows (sync PR previews to the cloud)
  • Deployment workflows
  • drift detection and reconciliation workflows

GitHub App

Install to have better plan previews in PRs

Slack App

Install in your Slack workspace to make the Terramate Bot available (in case of incidents via alerts in Terramate Cloud).