将弹性 IP 分配给自动扩展组实例的地形



我刚刚使用Terraform几天并寻求指导。我在 VPC 下有两个子网(私有、公有(。我尝试做的是为自动扩展组创建的每个实例分配弹性 IP,或者在实例被销毁时删除弹性 IP。我尝试点击此链接: 自动将公有 IP 分配给由 austo 扩展组创建的实例

因此,我创建了一个侦听端口 80 的弹性负载均衡器,并将其分配给自动扩展组和公有子网。我已经浏览了 AWS 文档,用于弹性负载均衡:https://docs.aws.amazon.com/elasticloadbalancing/latest/userguide/how-elastic-load-balancing-works.html 和 AWS 提供的其他各种文档,所以我可能只是错误地考虑了这个问题。我不确定如何为公有子网的自动扩展组的 EC2 实例分配弹性 IP,因此我唯一能想到的是它通过弹性负载均衡器自动处理?

我想到的第一个解决方案(甚至不确定我是否可以在不成为 EC2 实例的情况下做到这一点(,第二个解决方案来自第一个链接中的说明

  1. 将弹性 IP 分配给弹性负载均衡器而不是 EC2 实例,然后将 DNS 记录指向该弹性 IP,然后让负载均衡器处理其余部分
  2. 创建 DNS 记录以指向负载均衡器的 DNS

如果第二个选项是正确的,我会再试一次,我的.tf一定是不正确的。但是,如果有更好的选择,我想听听人们使用过的任何建议!

任何指南、文档或指导都会很棒!

第二个选项是正确的。您需要将 DNS 记录指向负载均衡器。在看起来像这样的地形中(您的 ELB 或 ALB 资源会有所不同(:

# Set up the load balancer
resource "aws_alb" "example" {
name            = "example"
internal        = false
security_groups = ["${aws_security_group.example.id}"]
subnets         = ["${data.aws_subnet_ids.example.ids}"]
}
# Get the zone id for the zone you are setting this in
data "aws_route53_zone" "example" {
name         = "example.com"
private_zone = false
}
# Set the record, replace <your dns name> with the name you want to use
resource "aws_route53_record" "build" {
provider = "aws"
zone_id  = "${data.aws_route53_zone.example.zone_id}"
name     = "<your dns name>"
type     = "A"
alias {
name                   = "${aws_alb.example.dns_name}"
zone_id                = "${aws_alb.eaxmple.zone_id}"
evaluate_target_health = false
}
}

最新更新