Terraform で動的ブロックを作成できません。モジュールを使用して ECS サービスを作成しようとしています。network_configuration
モジュールでは、変数が存在する場合にのみブロックを作成するように指定したいと考えています。ここに私のモジュールコードがあります:
resource "aws_ecs_service" "service" {
name = var.name
cluster = var.cluster
task_definition = var.task_definition
desired_count = var.desired_count
launch_type = var.launch_type
load_balancer {
target_group_arn = var.lb_target_group
container_name = var.container_name
container_port = var.container_port
}
dynamic "network_configuration" {
for_each = var.network_config
content {
subnets = network_configuration.value["subnets"]
security_groups = network_configuration.value["security_groups"]
assign_public_ip = network_configuration.value["public_ip"]
}
}
}
次は、実際のサービスのコードです。
module "fargate_service" {
source = "./modules/ecs/service"
name = "fargate-service"
cluster = module.ecs_cluster.id
task_definition = module.fargate_task_definition.arn
desired_count = 2
launch_type = "FARGATE"
lb_target_group = module.target_group.arn
container_name = "fargate_definition"
container_port = 8000
network_config = local.fargate_network_config
}
最後に、ローカル ファイルは次のようになります。
locals {
fargate_network_config = {
subnets = module.ec2_vpc.private_subnet_ids
public_ip = "false"
security_groups = [module.fargate_sg.id]
}
}
上記の構成では、変数が存在network_configiration
する場合にのみ 1 つのブロックを作成したいと考えています。network_config
私がそれを定義しない場合、モジュールがブロックを作成しないようにしたいと思います。エラーが発生してInvalid index
います。
network_configuration.value is tuple with 3 elements
The given key does not identify an element in this collection value: a number
is required.
コードの何が問題になっていますか? Terraform で動的ブロックを使用するのはこれが初めてですが、理解できるようになりたいです。ありがとう