Ссылка на общедоступный IP-адрес главной виртуальной машины кластера Azure ACS?

Я использую этот репозиторий для создания кластера kubernetes в Azure с помощью acs- двигатель.

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

Это будет использоваться для подключения по ssh к главной виртуальной машине (ssh user@public-ip), что важно, потому что я хочу запустить средства обеспечения local-exec для настройки моего кластера с помощью Ansible.

Я не верю, что это first_master_ip в приведенном ниже main.tf (это значение указано в файле variable.tf репозитория), хотя я также не знаю, как ссылаться на этот IP-адрес.

Еще одна вещь, которую я пробовал, - это получить общедоступный IP-адрес главной виртуальной машины с помощью командной строки azure, однако я также не добился успеха в этом, потому что я не знаю, как получить cluster-name, который будет передан в с az acs kubernetes browse -g <resource-group-name> -n <cluster-name>

Любая помощь будет принята с благодарностью, так как я действительно столкнулся с этим препятствием.

provider "azurerm" {
  subscription_id = "${var.azure_subscription_id}"
  client_id       = "${var.azure_client_id}"
  client_secret   = "${var.azure_client_secret}"
  tenant_id       = "${var.azure_tenant_id}"
}

# Azure Resource Group
resource "azurerm_resource_group" "default" {
  name     = "${var.resource_group_name}"
  location = "${var.azure_location}"
}

resource "azurerm_public_ip" "test" {
  name                         = "acceptanceTestPublicIp1"
  location                     = "${var.azure_location}"
  resource_group_name          = "${azurerm_resource_group.default.name}"
  public_ip_address_allocation = "static"
}

data "template_file" "acs_engine_config" {
  template = "${file(var.acs_engine_config_file)}"

  vars {
    master_vm_count = "${var.master_vm_count}"
    dns_prefix      = "${var.dns_prefix}"
    vm_size         = "${var.vm_size}"

    first_master_ip                 = "${var.first_master_ip}"
    worker_vm_count                 = "${var.worker_vm_count}"
    admin_user                      = "${var.admin_user}"
    ssh_key                         = "${var.ssh_key}"
    service_principle_client_id     = "${var.azure_client_id}"
    service_principle_client_secret = "${var.azure_client_secret}"
  }

}

# Locally output the rendered ACS Engine Config (after substitution has been performed)
resource "null_resource" "render_acs_engine_config" {
  provisioner "local-exec" {
    command = "echo '${data.template_file.acs_engine_config.rendered}' > ${var.acs_engine_config_file_rendered}"
  }

  depends_on = ["data.template_file.acs_engine_config"]
}

# Locally run the ACS Engine to produce the Azure Resource Template for the K8s cluster
resource "null_resource" "run_acs_engine" {
  provisioner "local-exec" {
    command = "acs-engine generate ${var.acs_engine_config_file_rendered}"
  }

  depends_on = ["null_resource.render_acs_engine_config"]
}

person Sean    schedule 25.05.2018    source источник


Ответы (1)


У меня нет опыта работы с terraform, но acs-engine устанавливает lb с общедоступным IP-адресом, который проходит через вашего мастера (или балансирует между несколькими мастерами). Вы найдете IP-адрес этого фунта, используя <dns_prefix>.<region>.cloudapp.azure.com.

Но если вам нужен IP-адрес для предоставления чего-то дополнительного, этого будет недостаточно, если у вас несколько мастеров.

person Nicolas Mommaerts    schedule 08.06.2018