ARM 模板 - 将动态数据磁盘添加到 VM 的值和参数?

ARM Templates - Values and parameters for Adding Dynamic Data disks to VMs?

我是 ARM 模板的新手。 在使用 1 个托管数据磁盘构建 VM 后,我从门户网站下载了一个 ARM 模板。 我的objective是用ARM Templates连续搭建好几个VM。 现在,使用相同的参数,除了 VM 名称,当然还有 NIC 和磁盘名称。 我注意到 parameters.json 文件有硬编码值,不能用作模板,所以我开始修改以查看如何使它更动态。 但是我不明白数据磁盘结构,在这个模板中,数据磁盘结构被划分为不同的组件,这让我很难为磁盘动态命名。

数据磁盘在模板中作为资源出现,然后作为 VM 的 属性 在复制函数中出现。 但是在参数文件中有两个对象,dataDisks 和dataDisksResources。 我不明白为什么参数有两个不同的对象而不是一个(例如,dataDisks 中的所有内容而不是也有 dataDisksResources)而且我也不明白为什么 VM 磁盘 属性 的参数不同并且不止是Disk Resource的参数。

这是template.json

{
    "$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
    "contentVersion": "1.0.0.0",
    "parameters": {
        "location": {
            "type": "string"
        },
        "subnetName": {
            "type": "string"
        },
        "virtualNetworkId": {
            "type": "string"
        },
        "virtualMachineName": {
            "type": "string"
        },
        "virtualMachineRG": {
            "type": "string"
        },
        "osDiskType": {
            "type": "string"
        },
        "dataDisks": {
            "type": "array"
        },
        "dataDiskResources": {
            "type": "array"
        },
        "virtualMachineSize": {
            "type": "string"
        },
        "adminUsername": {
            "type": "string"
        },
        "adminPassword": {
            "type": "secureString"
        },
        "diagnosticsStorageAccountName": {
            "type": "string"
        },
        "diagnosticsStorageAccountId": {
            "type": "string"
        },
        "diagnosticsStorageAccountType": {
            "type": "string"
        },
        "diagnosticsStorageAccountKind": {
            "type": "string"
        }
    },
    "variables": {
        "vnetId": "[parameters('virtualNetworkId')]",
        "subnetRef": "[concat(variables('vnetId'), '/subnets/', parameters('subnetName'))]",
        "nicName": "[concat(parameters('virtualMachineName'), substring(uniqueString(resourceGroup().id),0,4))]"
    },
    "resources": [
        {
            "name": "[variables('nicName')]",
            "type": "Microsoft.Network/networkInterfaces",
            "apiVersion": "2019-07-01",
            "location": "[parameters('location')]",
            "dependsOn": [],
            "properties": {
                "ipConfigurations": [
                    {
                        "name": "ipconfig1",
                        "properties": {
                            "subnet": {
                                "id": "[variables('subnetRef')]"
                            },
                            "privateIPAllocationMethod": "Dynamic"
                        }
                    }
                ]
            },
            "tags": {
            }
        },
        {
            "name": "[concat(parameters('virtualMachineName'),'_DataDisk_0')]",
            "type": "Microsoft.Compute/disks",
            "apiVersion": "2019-07-01",
            "location": "[parameters('location')]",
            "properties": "[parameters('dataDiskResources')[copyIndex()].properties]",
            "sku": {
                "name": "[parameters('dataDiskResources')[copyIndex()].sku]"
            },
            "copy": {
                "name": "managedDiskResources",
                "count": "[length(parameters('dataDiskResources'))]"
            },
            "tags": {
            }
        },
        {
            "name": "[parameters('virtualMachineName')]",
            "type": "Microsoft.Compute/virtualMachines",
            "apiVersion": "2019-07-01",
            "location": "[parameters('location')]",
            "dependsOn": [
                "managedDiskResources",
                "[concat('Microsoft.Network/networkInterfaces/', variables('nicName'))]",
                "[concat('Microsoft.Storage/storageAccounts/', parameters('diagnosticsStorageAccountName'))]"
            ],
            "properties": {
                "hardwareProfile": {
                    "vmSize": "[parameters('virtualMachineSize')]"
                },
                "storageProfile": {
                    "osDisk": {
                        "createOption": "fromImage",
                        "managedDisk": {
                            "storageAccountType": "[parameters('osDiskType')]"
                        }
                    },
                    "imageReference": {
                        "publisher": "MicrosoftVisualStudio",
                        "offer": "VisualStudio",
                        "sku": "VS-2017-Ent-Latest-Win10-N",
                        "version": "latest"
                    },
                    "copy": [
                        {
                            "name": "dataDisks",
                            "count": "[length(parameters('dataDisks'))]",
                            "input": {
                                "lun": "[parameters('dataDisks')[copyIndex('dataDisks')].lun]",
                                "createOption": "[parameters('dataDisks')[copyIndex('dataDisks')].createOption]",
                                "caching": "[parameters('dataDisks')[copyIndex('dataDisks')].caching]",
                                "writeAcceleratorEnabled": "[parameters('dataDisks')[copyIndex('dataDisks')].writeAcceleratorEnabled]",
                                "diskSizeGB": "[parameters('dataDisks')[copyIndex('dataDisks')].diskSizeGB]",
                                "managedDisk": {
                                    "id": "[coalesce(parameters('dataDisks')[copyIndex('dataDisks')].id, if(equals(parameters('dataDisks')[copyIndex('dataDisks')].name, json('null')), json('null'), resourceId('Microsoft.Compute/disks', parameters('dataDisks')[copyIndex('dataDisks')].name)))]",
                                    "storageAccountType": "[parameters('dataDisks')[copyIndex('dataDisks')].storageAccountType]"
                                }
                            }
                        }
                    ]
                },
                "networkProfile": {
                    "networkInterfaces": [
                        {
                            "id": "[resourceId('Microsoft.Network/networkInterfaces', variables('nicName'))]"
                        }
                    ]
                },
                "osProfile": {
                    "computerName": "[parameters('virtualMachineName')]",
                    "adminUsername": "[parameters('adminUsername')]",
                    "adminPassword": "[parameters('adminPassword')]",
                    "windowsConfiguration": {
                        "enableAutomaticUpdates": true,
                        "provisionVmAgent": true
                    }
                },
                "licenseType": "Windows_Server",
                "diagnosticsProfile": {
                    "bootDiagnostics": {
                        "enabled": true,
                        "storageUri": "[concat('https://', parameters('diagnosticsStorageAccountName'), '.blob.core.windows.net/')]"
                    }
                }
            },
            "tags": {
            }
        },
        {
            "name": "[parameters('diagnosticsStorageAccountName')]",
            "type": "Microsoft.Storage/storageAccounts",
            "apiVersion": "2019-06-01",
            "location": "[parameters('location')]",
            "properties": {},
            "kind": "[parameters('diagnosticsStorageAccountKind')]",
            "sku": {
                "name": "[parameters('diagnosticsStorageAccountType')]"
            },
            "tags": {
            }
        }
    ],
    "outputs": {
        "adminUsername": {
            "type": "string",
            "value": "[parameters('adminUsername')]"
        }
    }
}

这是 parameters.json

 {   
        "location": {
            "value": "location"
        },
        "subnetName": {
            "value": "subnetname"
        },
        "virtualNetworkId": {
            "value": "networkid"
        },
        "virtualMachineRG": {
            "value": "vmRG"
        },
        "osDiskType": {
            "value": "Standard_LRS"
        },
        "dataDisks": {
            "value": [
                {
                    "lun": 0,
                    "createOption": "attach",
                    "caching": "None",
                    "writeAcceleratorEnabled": false,
                    "id": null,
                    "storageAccountType": null,
                    "name": null,
                    "diskSizeGB": null,
                    "diskEncryptionSet": {
                        "id": null
                    }
                }
            ]
        },
        "dataDiskResources": {
            "value": [
                {
                    "sku": "Standard_LRS",
                    "properties": {
                        "diskSizeGB": 128,
                        "creationData": {
                            "createOption": "empty"
                        }
                    }
                }
            ]
        },
        "virtualMachineSize": {
            "value": "Standard_B4ms"
        },
        "adminUsername": {
            "value": "admin"
        },
        "diagnosticsStorageAccountName": {
            "value": "rg01diag"
        },
        "diagnosticsStorageAccountId": {
            "value": "Microsoft.Storage/storageAccounts/rg01diag"
        },
        "diagnosticsStorageAccountType": {
            "value": "Standard_LRS"
        },
        "diagnosticsStorageAccountKind": {
            "value": "Storage"
        } }

我也找不到此类模板的任何文档。我找到的所有快速模板都有一个更简单的版本。例如,它们在同一个模板文件中声明了所有磁盘属性,参数和属性更少,并且任何地方都没有任何 dataDisksResources 对象。

我想了解我需要如何修改这些磁盘结构以添加命名它们的动态命名,例如,就像 Azure 门户一样 (VMName_DataDisk_Lunnumber)

因为创建数据盘和附加数据盘时必须指定不同的输入,但你不必创建它,你可以告诉虚拟机创建它们。这将是这样做的一种方式:

      "dataDisks": [
        {
          "diskSizeGB": "[parameters('sizeOfEachDataDiskInGB')]",
          "lun": 0,
          "createOption": "Empty"
        },
        {
          "diskSizeGB": "[parameters('sizeOfEachDataDiskInGB')]",
          "lun": 1,
          "createOption": "Empty"
        },
        {
          "diskSizeGB": "[parameters('sizeOfEachDataDiskInGB')]",
          "lun": 2,
          "createOption": "Empty"
        },
        {
          "diskSizeGB": "[parameters('sizeOfEachDataDiskInGB')]",
          "lun": 3,
          "createOption": "Empty"
        }
      ],

而且您不必拥有单独的磁盘资源,它们会自动创建。您还可以添加一个名为 name 的 属性 来为它们指定一个名称。

https://github.com/Azure/azure-quickstart-templates/blob/master/101-vm-multiple-data-disk/azuredeploy.json