azure - Terraform 从托管磁盘镜像创建虚拟机

标签 azure terraform

我希望将市场镜像获取到托管磁盘,然后将此托管磁盘连接到具有 Terraform 的 Azure 虚拟机。

这可以更改虚拟机配置,而销毁和重建会使虚拟机保持完整。

我发现有人遇到类似的问题,但问题已被关闭,没有留下如何实现此目标的示例。

对于平台图片

data "azurerm_platform_image" "2016-Datacenter" {
  location  = "West Europe"
  publisher = "MicrosoftWindowsServer"
  offer     = "WindowsServer"
  sku       = "2016-Datacenter"
}

使用平台镜像创建托管磁盘

resource "azurerm_managed_disk" "Server-osdisk" {
  resource_group_name  = "rgroup"
  location             = "West Europe"
  create_option        = "FromImage"
  image_reference_id   = "${data.azurerm_platform_image.server2016.id}"
  disk_size_gb         = "127"
  name                 = "Server-osdisk"
  storage_account_type = "Standard_LRS"
}

然后在azurerm_virtual_machine中引用它

resource "azurerm_virtual_machine" "main" {
  # ...

  os_profile {
    computer_name  = "Server"
    admin_username = ""
    admin_password = ""
  }

  storage_os_disk {
    managed_disk_id = "${azurerm_managed_disk.Server-osdisk.id}"

    # os_type           = "Windows"
    managed_disk_type = "Premium_LRS"
    caching           = "ReadWrite"
    create_option     = "Attach"
    name              = "Server"
  }
}

抛出

Status=400 Code="InvalidParameter" Message="Required parameter 'osDisk.osType' is missing (null)." Target="osDisk.osType"

如果您在其中添加os_type,则会提示您无法拥有计算机名称、用户名和密码所需的os_profile

有同样问题的人

Terraform creating VM from managed disk image made in Packer

尝试了解决方案,但引发了上述错误

我错过了什么?

最佳答案

对于你的问题,我已经尝试解决了。你把东西改成你的,这只是一个例子。文件在这里:

resource "azurerm_resource_group" "main" {
  name = "acctestRG"
  location = "West Europe"
}

data "azurerm_platform_image" "linux" {
  location  = "West Europe"
  publisher = "Canonical"
  offer     = "UbuntuServer"
  sku       = "16.04-LTS"
}

resource "azurerm_managed_disk" "source" {
  name = "acctestmd1"
  location = "West Europe"
  resource_group_name = "${azurerm_resource_group.main.name}"
  storage_account_type = "Standard_LRS"
  create_option = "FromImage"
  image_reference_id = "${data.azurerm_platform_image.linux.id}"

  tags {
    environment = "staging"
  }
}

resource "azurerm_virtual_network" "main" {
  name                = "azuretestvnet"
  address_space       = ["10.0.0.0/16"]
  location            = "${azurerm_resource_group.main.location}"
  resource_group_name = "${azurerm_resource_group.main.name}"
}

resource "azurerm_subnet" "internal" {
  name                 = "internal"
  resource_group_name  = "${azurerm_resource_group.main.name}"
  virtual_network_name = "${azurerm_virtual_network.main.name}"
  address_prefix       = "10.0.2.0/24"
}

resource "azurerm_network_interface" "main" {
  name                = "azuretestnic"
  location            = "${azurerm_resource_group.main.location}"
  resource_group_name = "${azurerm_resource_group.main.name}"

  ip_configuration {
    name                          = "testconfiguration1"
    subnet_id                     = "${azurerm_subnet.internal.id}"
    private_ip_address_allocation = "dynamic"
  }
}

resource "azurerm_virtual_machine" "main" {
  name  = "azurevm"
  location = "West Europe"
  resource_group_name = "${azurerm_resource_group.main.name}"
  network_interface_ids = ["${azurerm_network_interface.main.id}"]
  vm_size = "Standard_DS1_v2"


  storage_os_disk {
    os_type = "Linux"
    name = "acctestmd1"
    managed_disk_type = "Standard_LRS"
    caching           = "ReadWrite"
    create_option     = "Attach"
    managed_disk_id   = "${azurerm_managed_disk.source.id}"
  }
  os_profile_linux_config {
    disable_password_authentication = false
  }
}

还有一些事情我遇到过,我认为你应该注意一下。

  1. 虚拟机中的 Managed_disk_type 和托管磁盘中的 storage_account_type 应相同。
  2. 两者中的托管磁盘名称应相同。

希望这对您有帮助。

关于azure - Terraform 从托管磁盘镜像创建虚拟机,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52723326/

相关文章:

amazon-web-services - AWS 上的 terraform 的多个可用区

terraform - 重命名而不是删除资源?

azure - 获取在 Azure Key Vault key 中上传的 pem 文件

azure - Azure AAD 租户与组织之间的区别

Azure Blob 存储 - 将存档的 blob 复制到在线层

.net - 使用 PromtDialog.Text 只显示文本而不是文本区域?

地形图和对象变量作为输入

terraform - 如何从地形状态设置封隔器变量

azure - Application Insights 采样会采样掉异常吗?

amazon-web-services - terraform aws_lb_listener_rule 条件参数在 terraform 0.12.20 中未被识别