Terraform игнорирует файл terraform.tfvars при использовании -var или -var-file

После нескольких месяцев, не связанных с изменениями инфраструктуры, я попытался загрузить наши файлы terragrunt на новую машину и натолкнулся на пару ошибок, которые я не мог найти решение.

В основном кажется, что terraform.tfvars файл (или любой *.auto.tfvars файл в этом отношении) получает игнорируется терраформ, когда есть -var или же -var-file вариант присутствует.

Мы используем иерархическую конфигурацию terragrunt, чтобы иметь разные настройки учетных данных для разных сред, поэтому есть account.tfvars файл, который содержит все данные.

Все сработало еще в августе этого года, так что, может быть, произошли изменения, которые я не заметил в журнале изменений?

специфичный для модуля terraform.tfvars :

terragrunt = {
  include {
    path = "${find_in_parent_folders()}"
  }

  terraform {
    source = "../../../modules//cockpit"
  }
}

bucket_prefix = "cockpit-"

domain_name = "cockpit.donutapp.io"

родитель terraform.tfvars :

terragrunt = {
  remote_state {
    backend = "s3"

    config {
      encrypt        = true
      bucket         = "my-${get_aws_account_id()}-tfstate"
      key            = "production/${path_relative_to_include()}/terraform.tfstate"
      region         = "us-east-1"
      dynamodb_table = "terraform-locks"
    }
  }

  terraform {
    extra_arguments "bucket" {
      commands = ["${get_terraform_commands_that_need_vars()}"]

      optional_var_files = [
        "${get_tfvars_dir()}/${find_in_parent_folders("account.tfvars", "ignore")}",
      ]

      arguments = [
        "-var",
        "terraform_bucket=my-${get_aws_account_id()}-tfstate",
      ]
    }

    extra_arguments "disable_input" {
      commands  = ["${get_terraform_commands_that_need_input()}"]
      arguments = ["-input=false"]
    }
  }
}

выполненная команда террагрунтом:

terraform plan -var terraform_bucket=my-accountid-tfstate \
               -var-file=some-path/../account.tfvars \
               -input=false

Когда я добавлю -var-file=terraform.tfvars в качестве аргумента terraform plan команда в .terragrunt-cache папка, она работает, поэтому она не загружается автоматически.

Какие-нибудь мысли?

1 ответ

Вышеуказанные механизмы установки переменных могут использоваться вместе в любой комбинации. Если одной и той же переменной присвоено несколько значений, Terraform использует последнее найденное значение, переопределяя все предыдущие значения. Обратите внимание, что одной и той же переменной не может быть присвоено несколько значений в одном источнике.

Terraform загружает переменные в следующем порядке, причем более поздние источники имеют приоритет над более ранними:

  • Переменные среды
  • Файл terraform.tfvars, если он есть.
  • Файл terraform.tfvars.json, если он есть.
  • Любые файлы *.auto.tfvars или *.auto.tfvars.json, обработанные в лексическом порядке их имен файлов.
  • Любые параметры -var и -var-file в командной строке в том порядке, в котором они указаны. (Сюда входят переменные, установленные рабочей областью Terraform Cloud.)

Ссылка: https://www.terraform.io/docs/language/values/variables.html

Другие вопросы по тегам