Проблемы с admin_ssh_key в блоке azurerm_virtual_machine с использованием HCL / Terraform

Я получаю следующую ошибку:

Error: Unsupported block type
front.tf line 164, in resource "azurerm_virtual_machine" "FrontEndVirtualMachines":
164:  admin_ssh_key {
Blocks of type "admin_ssh_key" are not expected here.

Я следую этому примеру:

https://docs.microsoft.com/en-us/azure/developer/terraform/create-linux-virtual-machine-with-infrastructure

В документе я заметил одну вещь: в разделе «Создание виртуальной машины» используются:

output "tls_private_key" { 
  value = "tls_private_key.Ssh.private_key_pem"
}

В то время как в разделе сценария Complete Terraform используется знак $ в фигурных скобках:

output "tls_private_key" { 
  value = "${tls_private_key.Ssh.private_key_pem}"
}

Я пробовал оба способа и столкнулся с той же проблемой.

Вот мой код:

#Create (and display) an SSH key
resource "tls_private_key" "Ssh" {
    algorithm = "RSA"
    rsa_bits = 4096
}
output "tls_private_key" { value = "${tls_private_key.Ssh.private_key_pem}" }

#Create 2 front end web servers VMs
resource "azurerm_virtual_machine" "FrontEndVirtualMachines" {
    count = 2
    name = "vmFront${count.index}"
    location = azurerm_resource_group.PWSDevResourceGroup.location
    availability_set_id = azurerm_availability_set.AvailibilitySet.id
    resource_group_name = azurerm_resource_group.PWSDevResourceGroup.name
    network_interface_ids = [element(azurerm_network_interface.FrontNetworkInterface.*.id, count.index)]
    vm_size = "A4_V2"

 # Uncomment this line to delete the OS disk automatically when deleting the VM
 # delete_os_disk_on_termination = true

 # Uncomment this line to delete the data disks automatically when deleting the VM
 # delete_data_disks_on_termination = true

#Define OS Image
 storage_image_reference {
    publisher = "MicrosoftWindowsServer"
    offer = "WindowsServer"
    sku = "2016-Datacenter"
    version = "latest"
   }

#Define OS Disk
storage_os_disk {
    name = "FrontOSDisk"
    caching = "ReadWrite"
    create_option = "FromImage"
    managed_disk_type = "Standard_LRS"
   }

#Define Secondary Storage Disk
storage_data_disk {
    name = "FrontDataDisk"
    create_option = "Empty"
    lun = 1
    disk_size_gb = "64"
    managed_disk_type = "Standard_LRS"
   }

#Define Admin Profile
 os_profile {
    computer_name = "Front"
    admin_username = "#######"
    admin_password = "#######"
    }

admin_ssh_key {
    username       = "azureuser"
    public_key     = tls_private_key.Ssh.public_key_openssh
    }

boot_diagnostics {
    enabled = true
    storage_uri = azurerm_storage_account.PWSDevStorageAcct.primary_blob_endpoint
    }

tags = {
    environment = "Front-End"
    }
}

person Dan    schedule 17.09.2020    source источник


Ответы (1)


Документация Azure предназначена для типа ресурса azurerm_linux_virtual_machine. Вы используете azurerm_virtual_machine. Этот ресурс был разделен на отдельные версии для Linux и Windows. Он по-прежнему поддерживается в 2.x, но функция заморожена. Кроме того, вы пытаетесь создать сервер Windows, который не поддерживает добавление admin_ssh_key. Вероятно, вы захотите использовать azurerm_windows_virtual_machine. Передать в кредиты

  admin_username      = "adminuser"
  admin_password      = "P@$$w0rd1234!"
person Christian Pearce    schedule 18.09.2020