Azure Powershell - ошибка проверки шаблона развертывания - Jtoken

Я пытаюсь развернуть несколько виртуальных машин по одной с помощью Powershell и файла шаблона, но продолжаю получать эту ошибку:

New-AzResourceGroupDeployment : 9:27:40 AM - Error: Code=InvalidTemplate; Message=Deployment template validation
failed: 'Template parameter JToken type is not valid. Expected 'String, Uri'. Actual 'Object'. Please see
https://aka.ms/resource-manager-parameter-files for usage details.'.
At C:\Users\jackk\OneDrive\Desktop\AzureAutomation\main.ps1:193 char:9
+         New-AzResourceGroupDeployment @parameters
+         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [New-AzResourceGroupDeployment], Exception
    + FullyQualifiedErrorId : Microsoft.Azure.Commands.ResourceManager.Cmdlets.Implementation.NewAzureResourceGroupDep
   loymentCmdlet

New-AzResourceGroupDeployment : The deployment validation failed
At C:\Users\jackk\OneDrive\Desktop\AzureAutomation\main.ps1:193 char:9
+         New-AzResourceGroupDeployment @parameters
+         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : CloseError: (:) [New-AzResourceGroupDeployment], InvalidOperationException
    + FullyQualifiedErrorId : Microsoft.Azure.Commands.ResourceManager.Cmdlets.Implementation.NewAzureResourceGroupDep
   loymentCmdlet

Вот соответствующая часть моего сценария PowerShell:

$location = "eastus2"
$networkInterfaceName = ""
$networkSecurityGroupName = ""
#$networkSecurityGroupRules = @()
$subnetName = $SubnetSelection
$virtualNetworkId = "/subscriptions/1234-1234-123-123-123/resourceGroups/MainGroup/providers/Microsoft.Network/virtualNetworks/Main_Network"
$virtualMachineName = ""
$virtualMachineComputerName = ""
$virtualMachineRG = $resourceGroupSelection
$osDiskType = "StandardSSD_LRS"
$virtualMachineSize = "Standard_B2s"
$adminUsername = "ADMIN"
$adminPassword = ConvertTo-SecureString "Password1234" -AsPlainText -Force
$diagnosticsStorageAccountName = $StorageAccountName
$diagnosticsStorageAccountId = $StorageAccountID
$imageName = $ImageSelection    

foreach ($i in 1..5) {
    
    $virtualMachineName = "test-$i".ToString()
    $virtualMachineComputerName = "test-$i".ToString()
    $rand = Get-Random -Maximum 1000
    $networkInterfaceName = "test-$i$rand".ToString()
    $networkSecurityGroupName = "test-$i-nsg".ToString()

    $paramObject = @{
        'location' = $location
        'networkInterfaceName' = $networkInterfaceName
        'networkSecurityGroupName' = $networkSecurityGroupName
        'subnetName' = $SubnetSelection
        'virtualNetworkId' = $virtualNetworkId
        'virtualMachineName' = $virtualMachineName
        'virtualMachineComputerName' = $virtualMachineComputerName
        'virtualMachineRG' = $resourceGroupSelection
        'osDiskType' = $osDiskType
        'virtualMachineSize' = $virtualMachineSize
        'adminUsername' = $adminUsername
        'adminPassword' = $adminPassword
        'diagnosticsStorageAccountName' = $diagnosticsStorageAccountName
        'diagnosticsStorageAccountId' = $diagnosticsStorageAccountId
        'imageName' = $imageName
    }

    $parameters = @{
        'ResourceGroupName' = $resourceGroupSelection
        'TemplateFile' = $PathTemplate
        'TemplateParameterObject' = $paramObject
        'Verbose' = $True
    }

    New-AzResourceGroupDeployment @parameters

}

Предположим, что любые переменные, не определенные в этом фрагменте, являются строками, определенными в другом месте с действительной информацией.

Файл шаблона, который я использую:

{
    "$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
    "contentVersion": "1.0.0.0",
    "parameters": {
        "location": {
            "type": "String"
        },
        "networkInterfaceName": {
            "type": "String"
        },
        "networkSecurityGroupName": {
            "type": "String"
        },
        "networkSecurityGroupRules": {
            "type": "Array",
            "defaultValue": []
        },
        "subnetName": {
            "type": "String"
        },
        "virtualNetworkId": {
            "type": "String"
        },
        "virtualMachineName": {
            "type": "String"
        },
        "virtualMachineComputerName": {
            "type": "String"
        },
        "virtualMachineRG": {
            "type": "String"
        },
        "osDiskType": {
            "type": "String"
        },
        "virtualMachineSize": {
            "type": "String"
        },
        "adminUsername": {
            "type": "String"
        },
        "adminPassword": {
            "type": "SecureString"
        },
        "diagnosticsStorageAccountName": {
            "type": "String"
        },
        "diagnosticsStorageAccountId": {
            "type": "String"
        },
        "imageName": {
            "type": "String"
        }
    },
    "variables": {
        "nsgId": "[resourceId(resourceGroup().name, 'Microsoft.Network/networkSecurityGroups', parameters('networkSecurityGroupName'))]",
        "vnetId": "[parameters('virtualNetworkId')]",
        "subnetRef": "[concat(variables('vnetId'), '/subnets/', parameters('subnetName'))]"
    },
    "resources": [
        {
            "type": "Microsoft.Network/networkInterfaces",
            "apiVersion": "2019-07-01",
            "name": "[parameters('networkInterfaceName')]",
            "location": "[parameters('location')]",
            "dependsOn": [
                "[concat('Microsoft.Network/networkSecurityGroups/', parameters('networkSecurityGroupName'))]"
            ],
            "properties": {
                "ipConfigurations": [
                    {
                        "name": "ipconfig1",
                        "properties": {
                            "subnet": {
                                "id": "[variables('subnetRef')]"
                            },
                            "privateIPAllocationMethod": "Dynamic"
                        }
                    }
                ],
                "networkSecurityGroup": {
                    "id": "[variables('nsgId')]"
                }
            }
        },
        {
            "type": "Microsoft.Network/networkSecurityGroups",
            "apiVersion": "2019-02-01",
            "name": "[parameters('networkSecurityGroupName')]",
            "location": "[parameters('location')]",
            "properties": {
                "securityRules": "[parameters('networkSecurityGroupRules')]"
            }
        },
        {
            "type": "Microsoft.Compute/virtualMachines",
            "apiVersion": "2019-07-01",
            "name": "[parameters('virtualMachineName')]",
            "location": "[parameters('location')]",
            "dependsOn": [
                "[concat('Microsoft.Network/networkInterfaces/', parameters('networkInterfaceName'))]"
            ],
            "properties": {
                "hardwareProfile": {
                    "vmSize": "[parameters('virtualMachineSize')]"
                },
                "storageProfile": {
                    "osDisk": {
                        "createOption": "fromImage",
                        "managedDisk": {
                            "storageAccountType": "[parameters('osDiskType')]"
                        }
                    },
                    "imageReference": {
                        "id": "[parameters('imageName')]"
                    }
                },
                "networkProfile": {
                    "networkInterfaces": [
                        {
                            "id": "[resourceId('Microsoft.Network/networkInterfaces', parameters('networkInterfaceName'))]"
                        }
                    ]
                },
                "osProfile": {
                    "computerName": "[parameters('virtualMachineComputerName')]",
                    "adminUsername": "[parameters('adminUsername')]",
                    "adminPassword": "[parameters('adminPassword')]",
                    "windowsConfiguration": {
                        "enableAutomaticUpdates": true,
                        "provisionVmAgent": true
                    }
                },
                "diagnosticsProfile": {
                    "bootDiagnostics": {
                        "enabled": true,
                        "storageUri": "[concat('https://', parameters('diagnosticsStorageAccountName'), '.blob.core.windows.net/')]"
                    }
                }
            }
        }
    ],
    "outputs": {
        "adminUsername": {
            "type": "String",
            "value": "[parameters('adminUsername')]"
        }
    }
}

Я перепробовал все, что мог придумать, и, кажется, сузил проблему до networkSecurityGroupRules. Я взял этот файл шаблона из действующего развертывания в Azure, и в файле параметров, который идет с networkSecurityGroupRules, было установлено значение []. Поэтому я создал для него значение по умолчанию, но оно не работает. Я также пробовал объявить его как пустой массив в PowerShell и передать его с другими paramObject, но получаю ту же ошибку. Я тоже пробовал ArrayList, но безрезультатно. Я также заполнил файл parameter.json точными значениями, которые передаю ему в $paramObjects, и он работает безупречно. Если я изменю defaultValue на null, то при развертывании он попросит меня заполнить networkSecurityGroupRules [0], networkSecurityGroupRules [1] и т. Д. Я действительно не знаю, в чем проблема, поэтому любая помощь будет очень признательна, спасибо .


person William Jones    schedule 16.09.2020    source источник
comment
Не могли бы вы сообщить мне сообщение об ошибке при использовании "defaultValue": []?   -  person Jim Xu    schedule 17.09.2020
comment
Я получаю то же самое сообщение об ошибке, что и в начале. Я решил полностью удалить группу безопасности сети из шаблона и вместо этого создаю ее вручную, используя New-AzNetworkSecurityGroup, а затем использую шаблон. Это было моим решением проблемы, но я все равно буду продолжать в том же духе, потому что я хотел бы знать, почему то, что у меня было выше, не сработало.   -  person William Jones    schedule 17.09.2020
comment
Поскольку вы не хотите определять правила в своей NSG, почему вы добавляете securityRules в свой шаблон. Это не обязательно: docs.microsoft.com/en-us /azure/templates/microsoft.network/   -  person Jim Xu    schedule 18.09.2020
comment
Я уже пытался удалить его, но тогда он предложит мне правила независимо от запуска скрипта в форме: networksecurityrules [0], networksecurityrules [1] и т. Д.   -  person William Jones    schedule 19.09.2020


Ответы (1)


Нашел проблему. Все в paramObject должно быть в кавычках. Например, 'location' = $location должно быть 'location' = "$location"

person William Jones    schedule 21.09.2020