Terraform 0.11

azurerm_virtual_machine_data_disk_attachment




terraform

azurerm_virtual_machine_data_disk_attachment

किसी वर्चुअल मशीन में डिस्क संलग्न करना।

उदाहरण उपयोग

variable "prefix" {
  default = "example"
}

locals {
  vm_name = "${var.prefix}-vm"
}

resource "azurerm_resource_group" "main" {
  name = "${var.prefix}-resources"
  location = "West Europe"
}

resource "azurerm_virtual_network" "main" {
  name                = "${var.prefix}-network"
  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                = "${var.prefix}-nic"
  location            = "${azurerm_resource_group.main.location}"
  resource_group_name = "${azurerm_resource_group.main.name}"

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

resource "azurerm_virtual_machine" "test" {
  name                  = "${local.vm_name}"
  location              = "${azurerm_resource_group.test.location}"
  resource_group_name   = "${azurerm_resource_group.test.name}"
  network_interface_ids = ["${azurerm_network_interface.test.id}"]
  vm_size               = "Standard_F2"

  storage_image_reference {
    publisher = "Canonical"
    offer     = "UbuntuServer"
    sku       = "16.04-LTS"
    version   = "latest"
  }

  storage_os_disk {
    name              = "myosdisk1"
    caching           = "ReadWrite"
    create_option     = "FromImage"
    managed_disk_type = "Standard_LRS"
  }

  os_profile {
    computer_name  = "${local.vm_name}"
    admin_username = "testadmin"
    admin_password = "Password1234!"
  }

  os_profile_linux_config {
    disable_password_authentication = false
  }
}

resource "azurerm_managed_disk" "test" {
  name                 = "${local.vm_name}-disk1"
  location             = "${azurerm_resource_group.test.location}"
  resource_group_name  = "${azurerm_resource_group.test.name}"
  storage_account_type = "Standard_LRS"
  create_option        = "Empty"
  disk_size_gb         = 10
}

resource "azurerm_virtual_machine_data_disk_attachment" "test" {
  managed_disk_id    = "${azurerm_managed_disk.test.id}"
  virtual_machine_id = "${azurerm_virtual_machine.windows.id}"
  lun                = "10"
  caching            = "ReadWrite"
}

तर्क संदर्भ

निम्नलिखित तर्क समर्थित हैं:

  • virtual_machine_id - (आवश्यक) वर्चुअल मशीन की वह आईडी जिससे डाटा डिस्क जुड़ी होनी चाहिए। इस परिवर्तन से एक नया संसाधन बनने के लिए बाध्य होता है।

  • managed_disk_id - (आवश्यक) एक मौजूदा प्रबंधित डिस्क की आईडी जो संलग्न होनी चाहिए। इस परिवर्तन से एक नया संसाधन बनने के लिए बाध्य होता है।

  • lun - (आवश्यक) डेटा डिस्क की तार्किक इकाई संख्या, जिसे वर्चुअल मशीन के भीतर अद्वितीय होना चाहिए। इस परिवर्तन से एक नया संसाधन बनने के लिए बाध्य होता है।

  • caching - (आवश्यक) इस डेटा डिस्क के लिए कैशिंग आवश्यकताओं को निर्दिष्ट करता है। संभावित मानों में None , ReadOnly और ReadWrite

  • create_option - (वैकल्पिक) डेटा डिस्क का विकल्प बनाएँ, जैसे कि Empty या AttachAttach करने के लिए चूक। इस परिवर्तन से एक नया संसाधन बनने के लिए बाध्य होता है।

संदर्भ संदर्भित करता है

निम्नलिखित विशेषताएँ निर्यात की जाती हैं:

  • id - वर्चुअल मशीन डेटा डिस्क अटैचमेंट की आईडी।

आयात

वर्चुअल मशीन डाटा डिस्क अटैचमेंट्स को resource id का उपयोग करके आयात किया जा सकता है, जैसे

terraform import azurerm_virtual_machine_data_disk_attachment.test /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/mygroup1/providers/microsoft.compute/virtualMachines/machine1/dataDisks/disk1