Почему terraform терпит неудачу с «Аргумент с именем« flow_log_destination_type »здесь не ожидается»? - PullRequest
0 голосов
/ 30 апреля 2020

"В то время как я использую terraform для создания vp c модуля лога потока в корзину s3, его ошибки выброса, такие как: Аргумент с именем" flow_log_destination_type "здесь не ожидается. Аргумент с именем" flow_log_destination_arn "здесь не ожидается. В в документах Terraform я вижу детали, которые нужно заполнить, например log_destination_type & log_destination_arn, и я нашел несколько документов на GitHub, в которых точно написан тот же код, но при попытке он не работает для меня

Произошла следующая ошибка:

Error: Unsupported argument

  on main.tf line 52, in module "vpc_with_flow_logs_s3_bucket":
  52:   flow_log_destination_type = "s3"

An argument named "flow_log_destination_type" is not expected here.


Error: Unsupported argument

  on main.tf line 53, in module "vpc_with_flow_logs_s3_bucket":
  53:   flow_log_destination_arn  = "${aws_s3_bucket.terra-test2-lifecycle.arn}"

An argument named "flow_log_destination_arn" is not expected here.


Error: Unsupported argument

  on main.tf line 55, in module "vpc_with_flow_logs_s3_bucket":
  55:   vpc_flow_log_tags = {

An argument named "vpc_flow_log_tags" is not expected here.

Где я делаю что-то не так? "

module "vpc" {
  source  = "terraform-aws-modules/vpc/aws"
  version = "2.33.0"
  # Interpolated from the workspace
  name = "${terraform.workspace}"
  cidr = var.vpc_cidr

  azs             = var.vpc_azs
  private_subnets = var.vpc_private_subnets
  public_subnets  = var.vpc_public_subnets

  enable_nat_gateway = var.vpc_enable_nat_gw
  single_nat_gateway = var.vpc_single_nat_gw

  public_subnet_tags = {
    Name = "${terraform.workspace}-public"
  }

  private_subnet_tags = {
    Name = "${terraform.workspace}-private"
  }

  tags = {
    Name = "${terraform.workspace}"
  }

  vpc_tags = {
    owner       = "PEDevOps"
    environment = "${terraform.workspace}"
    version     = "0.0.1"
    managedby   = "Terraform"
  }
}

module "vpc_with_flow_logs_s3_bucket" {
  source = "../../"
  log_destination_type = "s3"
  log_destination_arn  = "${aws_s3_bucket.terra-test2-lifecycle.arn}"

  vpc_flow_log_tags = {
    Name = "vpc-flow-logs-s3-bucket"
  }

}

resource "aws_s3_bucket" "terra-test-lifecycle" {
  bucket = "terra-test-lifecycle"
  acl    = "private"

  lifecycle_rule {
    id      = "log"
    enabled = true

    prefix = "log/"

    tags = {
      "rule"      = "log"
      "autoclean" = "true"
    }

    transition {
      days          = 30
      storage_class = "STANDARD_IA" # or "ONEZONE_IA"
    }

    expiration {
      days = 60
    }
  }
  lifecycle_rule {
    id      = "tmp"
    prefix  = "tmp/"
    enabled = true

    expiration {
      date = "2020-06-06"
    }
  }
}

Почему терраформ завершается неудачно с" Аргумент с именем "flow_log_destination_type" здесь не ожидается "?

Ответы [ 2 ]

0 голосов
/ 03 мая 2020

Модуль в "../../" не объявляет ни одну из log_destination_type , log_destination_arn или vpc_flow_log_tags переменных, и Terraform считает его ошибка при назначении необъявленным переменным в блоке модуля, например:

module "vpc_with_flow_logs_s3_bucket" {
  source = "../../"
  log_destination_type = "s3"
  log_destination_arn  = "${flow_log_destination_arn}"

  vpc_flow_log_tags = {
    Name = "vpc-flow-logs-s3-bucket"
  }
}

Скорее всего, "../../" - это неверный исходный путь для модуля vpc_with_flow_logs_s3_bucket и Вы должны это исправить. Если вы находитесь в исходном пути для модуля, где объявлен этот блок модуля, и вы запускаете cd ../../, вы попали в каталог с vpc_with_flow_logs_s3_bucket кодом Terraform? Если нет, то source установлен неправильно, и вам нужно исправить это.

Если "../../" - правильный путь, то вы должны добавить объявления отсутствующих переменных.

variable "log_destination_type" {
    type = string
}

variable "log_destination_arb" {
    type = string
}

variable "vpc_flow_log_tags" {
    type = map(string)
}
0 голосов
/ 30 апреля 2020

Эта ошибка возникает, если вы передаете переменную, которую модуль не ожидает.

Например,

module "vpc_with_flow_logs_s3_bucket" {
  source = "../../"
  log_destination_type = "s3"
  log_destination_arn  = "${flow_log_destination_arn}"

  vpc_flow_log_tags = {
    Name = "vpc-flow-logs-s3-bucket"
  }

}

Если вы укажете это, он выдаст ошибку, если определена переменная flow_log_destination_arn в main.tf и , а не в variables.tf

source: ../../vpc_with_flow_logs_s3_bucket/main.tf

resource "aws_flow_log" "example" {
  iam_role_arn    = "${aws_iam_role.example.arn}"
  log_destination = "${aws_cloudwatch_log_group.example.arn}"
  traffic_type    = "ALL"
  vpc_id          = "${aws_vpc.example.id}"
}
...