Как назначить IP AWS Elasti c вновь созданному экземпляру EC2 с помощью Terraform без его переназначения при создании другого экземпляра? - PullRequest
0 голосов
/ 06 августа 2020

В настоящее время у меня есть следующий план Terraform:

provider "aws" {
  region = var.region
}

resource "aws_instance" "ec2" {
  ami             = var.ami
  instance_type   = var.instanceType
  subnet_id       = var.subnet 
  security_groups = var.securityGroups 

  timeouts {
    create = "2h"
    delete = "2h"
  }

  tags = {
    Name = "${var.ec2ResourceName}"
    CoreInfra = "false"
  }

  lifecycle {
    prevent_destroy = true
  }

  key_name = "My_Key_Name"

  connection {
    type        = "ssh"
    user        = "ec2-user"
    password    = ""
    private_key = file(var.keyPath)
    host        = self.public_ip
  }

  provisioner "file" {
    source      = "/home/ec2-user/code/backend/ec2/setup_script.sh"
    destination = "/tmp/setup_script.sh"
  }

  provisioner "remote-exec" {
    inline = [
      "chmod +x /tmp/setup_script.sh",
      "bash /tmp/setup_script.sh ${var.ec2ResourceName}"
    ]
  }
}

resource "aws_eip" "eip_manager" {
  name = "eip-${var.ec2ResourceName}"
  instance = aws_instance.ec2.id
  vpc = true
  
  tags = {
    Name = "eip-${var.ec2ResourceName}"
  }

  lifecycle {
    prevent_destroy = true
  }
}

Этот план можно запускать несколько раз, каждый раз создавая один экземпляр EC2, не удаляя предыдущий. Однако существует единственный IP-адрес Elasti c, который в конечном итоге переназначается самому недавно созданному экземпляру EC2. Как я могу добавить Elasti c IP к каждому новому экземпляру, который не переназначается?

1 Ответ

0 голосов
/ 07 августа 2020

возможно с aws_eip_association, вот фрагмент:

resource "aws_eip_association" "eip_assoc" {
  instance_id   = aws_instance.ec2.id
  allocation_id = aws_eip.eip_manager.id
}

Подробнее здесь: https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/eip_association

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...