Есть ли способ генерировать бесконфликтный диапазон ip для выбранного VPC(сети), чтобы использовать его в качестве главного блока GKE ipv4 cidr на terraform?
Я хотел бы получить способ автоматического создания значения для master_ipv4_cidr_block при создании частного кластера GKE.
- В данный момент я использую ресурс google_compute_global_address для выделения диапазона ip. Но я не думаю, что это правильное использование для этого ресурса, и этот вид ресурса имеет цитату всего из 5 элементов.
resource "google_compute_global_address" "default" {
provider = "google-beta"
project = "${var.project}"
name = "${var.cluster_name}"
description = "Private address for the gke master instance of ${var.cluster_name}"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 28
network = "${var.network}"
}
data "google_compute_zones" "available" {
project = "${var.project}"
region = "${var.region}"
status = "UP"
}
/******************************************
Cluster configuration
*****************************************/
resource "google_container_cluster" "default" {
project = "${var.project}"
name = "${var.cluster_name}"
zone = "${data.google_compute_zones.available.names[0]}"
additional_zones = ["${data.google_compute_zones.available.names[1]}"]
# We can't create a cluster with no node pool defined, but we want to only use
# separately managed node pools. So we create the smallest possible default
# node pool and immediately delete it.
remove_default_node_pool = true
initial_node_count = 1
min_master_version = "1.11.6-gke.6"
master_auth {...}
ip_allocation_policy {..}
private_cluster_config {
enable_private_endpoint = "false"
enable_private_nodes = "true"
master_ipv4_cidr_block = "${google_compute_global_address.default.address}/${google_compute_global_address.default.prefix_length}"
}
network = "${var.network}"
# https://github.com/terraform-providers/terraform-provider-google/issues/2231
master_authorized_networks_config {...}
maintenance_policy {...}
logging_service = "logging.googleapis.com/kubernetes"
monitoring_service = "monitoring.googleapis.com/kubernetes"
resource_labels {...}
}
resource "google_container_node_pool" "default" {...}