我通过子模块调用根模块如下:
子模块 - main.tf
module "create_network_lb" {
source = "../../modules/lb_test"
for_each = var.target_groups
name = each.key
tg_name = each.value.tg_name
tg_backend_port = each.value.tg_backend_port
tg_backend_protocol = each.value.tg_backend_protocol
tg_hc_port = each.value.tg_hc_port
tg_hc_protocol = each.value.tg_hc_protocol
tg_htl_port = each.value.tg_htl_port
tg_htl_protocol = each.value.tg_htl_protocol
tg_htl_action = lookup(each.value, "tg_htl_action", "forward")
subnets = tolist(data.aws_subnet_ids.private_compute[0].ids)
vpc_id = sort(data.aws_vpcs.platform_private_vpc.ids)[0]
}
子模块 - vars.tf
variable "target_groups" {
description = "A list of maps containing key/value pairs that define the target groups to be created. Order of these maps is important and the index of these are to be referenced in listener definitions. Required key/values: name, backend_protocol, backend_port"
type = map
default = {
lb-1 = {
tg_name = "test1"
tg_backend_protocol = "TCP"
tg_backend_port = "80"
tg_target_type = "instance"
tg_deregistration_delay = "180"
tg_hc_healthy_threshold = 3
tg_hc_interval = 30
tg_hc_port = 80
tg_hc_protocol = "TCP"
tg_hc_unhealthy_threshold = 3
tg_htl_port = "80"
tg_htl_protocol = "TCP"
}
lb-2 = {
tg_name = "test2"
tg_backend_protocol = "TCP"
tg_backend_port = "8080"
tg_target_type = "instance"
tg_deregistration_delay = "180"
tg_hc_healthy_threshold = 3
tg_hc_interval = 30
tg_hc_port = 8080
tg_hc_protocol = "TCP"
tg_hc_unhealthy_threshold = 3
tg_htl_port = "80"
tg_htl_protocol = "TCP"
}
}
}
根模块 - main.tf
resource "aws_lb_target_group" "main" {
name = var.tg_name
vpc_id = var.vpc_id
port = var.tg_backend_port
protocol = var.tg_backend_protocol
depends_on = [aws_lb.default]
lifecycle {
create_before_destroy = true
}
}
resource "aws_lb_listener" "frontend_http_tcp" {
load_balancer_arn = aws_lb.default.arn
port = var.tg_htl_port
protocol = var.tg_htl_protocol
default_action {
type = var.tg_htl_action
target_group_arn = aws_lb_target_group.main.arn
}
}
根模块 - output.tf
output "target_group_arns" {
description = "ARNs of the target groups. Useful for passing to your Auto Scaling group."
value = aws_lb_target_group.main.arn
}
在子模块内部,调用附加模块来创建 Auto Scaling Group
module "create_autoscaling_group" {
source = "../../modules/cloudformation_stack_autoscaling"
template_name = "launch-template"
cf_stack_name = "stack"
autoscaling_group_name = "asg"
instance_type = var.vm_type
block_device_mappings = var.block_device_mappings
image_id = data.aws_ami.centos_ami.image_id
vpc_security_group_ids = concat(data.aws_security_groups.security_group_ids.ids, [module.create_security_group.id])
user_data_base64 = data.template_cloudinit_config.config.rendered
iam_instance_profile_name = var.iam_instance_profile_name
volume_tags = merge(local.vmss_tags,{"fds:cloudformation:stack-name"=local.stack_tag})
ec2_tags = var.vmss_tags
subnet_ids = tolist(data.aws_subnet_ids.private_compute[0].ids)
max_size = var.vm_count != 0 ? var.vm_count : var.max_size
min_size = var.vm_count != 0 ? var.vm_count : var.min_size
desired_capacity = var.vm_count != 0 ? var.vm_count : var.desired_capacity
health_check_type = var.health_check_type
health_check_grace_period = var.health_check_grace_period
target_group_arns = module.create_network_lb[*].target_group_arns
注意变量“target_group_arns”。在这里,我需要通过调用“create_network_lb”模块创建的所有目标组的 arn,以便所有 LB 及其关联的目标组都由 1 个 Auto Scaling 组管理。
从我读到的内容来看,当使用 for_each 时,就像我对 'create_network_lb' 模块调用所做的那样,我不能使用 splat 表达式。我尝试使用列表理解,但一定是做错了。任何帮助将不胜感激。
答案 0 :(得分:0)
您的模块 target_group_arns
将是地图,而不是列表。因此,您应该能够将所有 target_group_arns = values(module.create_network_lb)[*].target_group_arns
引用为:
{{1}}