Как создать экземпляр GCP с общедоступным IP-адресом с помощью terraform

Мне нужно создать экземпляр виртуальной машины в gcp с общедоступным IP-адресом (экземпляр может случайным образом выбрать один для себя) без явного определения.

Так как я могу это сделать?

Это команда gcloud, которую я могу использовать для этого (создать экземпляр vm с автоматически назначенным общедоступным IP-адресом)

gcloud compute instances create controller-1 \
    --async \
    --boot-disk-size 200GB \
    --can-ip-forward \
    --image-family ubuntu-2004-lts \
    --image-project ubuntu-os-cloud \
    --machine-type e2-standard-2 \
    --private-network-ip 10.240.0.10 \
    --scopes compute-rw,storage-ro,service-management,service-control,logging-write,monitoring \
    --subnet kubernetes \
    --tags kubernetes-the-hard-way,controller

Приведенная выше команда создаст виртуальную машину как с внутренним IP 10.240.0.10, так и с общедоступным IP с некоторым случайно выбранным IP-адресом.

Итак, я хочу достичь той же цели с terraform

Это мой terraform код. но как я могу это сделать?

resource "google_compute_instance" "controllers" {
  name         = "controller-0"
  machine_type = "e2-standard-2"
  zone         = var.zone

  can_ip_forward = true



  tags = ["kubernetes-the-hard-way", "controller"]
  

  boot_disk {
    initialize_params {
      image = "ubuntu-2004-focal-v20200720"
    }
  }

  network_interface {
    subnetwork = google_compute_subnetwork.kubernetes.name
    network_ip = "10.240.0.10"  // private ip but how to assign a public ip (randomly)  
  }

  service_account {
    scopes = ["compute-rw", "storage-ro", "service-management", "service-control", "logging-write", "monitoring"]
  }
}

person Jananath Banuka    schedule 13.08.2020    source источник


Ответы (2)


Пустой блок access_config назначит вашему экземпляру внешний эфемерный IP-адрес.

network_interface {
    network = "default"
    access_config {}
}
person divya nayaka    schedule 14.08.2020

Похоже, вам нужно указать access_config в network_interface, чтобы назначить внешний (общедоступный) IP-адрес экземпляру GCE в соответствии с этот пример из terraform.

resource "google_compute_address" "static" {
  name = "ipv4-address"
}

data "google_compute_image" "debian_image" {
  family  = "debian-9"
  project = "debian-cloud"
}

resource "google_compute_instance" "instance_with_ip" {
  name         = "vm-instance"
  machine_type = "f1-micro"
  zone         = "us-central1-a"

  boot_disk {
    initialize_params {
      image = data.google_compute_image.debian_image.self_link
    }
  }

  network_interface {
    network = "default"
    access_config {
      nat_ip = google_compute_address.static.address
    }
  }
}

Compute Engine Google Cloud Platform поддерживает два типа внешних IP-адресов:

Статические внешние IP-адреса

Эфемерные внешние IP-адреса

person Pralove Tandukar    schedule 14.08.2020
comment
... скриншот? - person Thomas8; 11.05.2021
comment
Стоит отметить, что вы платите за статический IP-адрес около 7,20 доллара в месяц, как я проверял. Эфемерный вариант бесплатен. - person GoForth; 06.07.2021