Настройка Terraform и GCP composer

# #google-cloud-platform #terraform #google-cloud-composer #terraform-provider-gcp

Вопрос:

Я пытаюсь развернуть GCP composer с помощью terraform, но возникла проблема ->

Ошибка: Неподдерживаемый тип блока вкл. composer.tf строка 43, в ресурсе «google_composer_environment» «тест»: 34: encryption_config { Блоки типа «encryption_config» здесь не ожидаются.

Вот composer.tf файл:

 resource "google_composer_environment" "test" {
  name   = "dwh_composer"
  region = local.default_region
  config {
    node_count = 3
    node_config {
      zone         = local.default_zone
      machine_type = "e2-medium"
      network    = google_compute_network.test.id
      subnetwork = google_compute_subnetwork.test.id
      service_account = google_service_account.test.name
    }
    software_config {
      image_version = "composer-1.17.0-preview.9-airflow-2.1.1"
      python_version = "3"
      airflow_config_overrides = {
        core-load_example = "True"
      }
      pypi_packages = {
        numpy = ""
        scipy = "==1.1.0"
      }
      env_variables = {
        FOO = "bar"
        R1 = "test5"
        evvv_qqq_d = "test1"
        M1 = "test3"
        AIRFLOW-3 = "test2"
      }
    }
    private_environment_config {
      enable_private_endpoint = true
    }
    encryption_config {
      kms_key_name = google_kms_crypto_key.dwh_composer_crypto_key.name
    }
  }
}

resource "google_kms_key_ring" "data_warehouse_kms_keyring" {
  name     = "data-warehouse-kms-keyring"
  location = "europe-west4"
}

resource "google_kms_crypto_key" "dwh_composer_crypto_key" {
  name            = "dwh-composer-crypto-key"
  key_ring        = google_kms_key_ring.data_warehouse_kms_keyring.self_link
}
 

Вот main.tf файл:

 terraform {
  required_version = "1.0.0"

  backend "gcs" {
    bucket = "terraform-data-warehouse"
    prefix = "gcp/data-warehouse/composer"
  }

  required_providers {
    google = {
      source  = "hashicorp/google"
      version = "~> 3.70.0"
    }
    google-beta = {
      source  = "hashicorp/google-beta"
      version = "~> 3.70.0"
    }
  }
}

# -- Providers

provider "google" {
  project = local.project_id
}

provider "google-beta" {
  project = local.project_id
}

# -- common public state

data "terraform_remote_state" "common" {
  backend = "gcs"

  config = {
    bucket = "terraform-public"
    prefix = "common"
  }
}

# -- Local variables
locals {
  default_zone = "europe-west4-a"
  default_region = "europe-west1"
  project_id = "my-project"
  team_group = data.terraform_remote_state.common.outputs.teams.data_warehouse.group
  default_multi_region = "EU"
}
 

Не могли бы вы мне помочь?

Комментарии:

1. Что произойдет, если вы попытаетесь выполнить следующее: kms_key_name = «проекты/[ИДЕНТИФИКАТОР ПРОЕКТА]/местоположения/[МЕСТОПОЛОЖЕНИЕ]/Связки ключей/[СВЯЗКА КЛЮЧЕЙ]/криптокейсы/[КЛЮЧ]»

2. Та же проблема: блоки типа «encryption_config» здесь не ожидаются.

Ответ №1:

Проблема, с которой вы столкнулись, заключается в том, что encryption_config это бета-версия google_composer_environment ресурса terraform в соответствии с документами. Просто укажите поставщика бета — версии в ресурсе:

 resource "google_composer_environment" "test" {
  name   = "dwh_composer"
  region = local.default_region
  provider = google-beta
  ...
}
 

Не забудьте terraform init сделать это раньше, чтобы бета-версия провайдера Google была загружена и доступна для использования.