gpt4 book ai didi

json - 如何通过 ARM 模板在应用程序网关中创建 backendAddressPools、frontendports 的多个实例

转载 作者:行者123 更新时间:2023-12-02 08:00:49 26 4
gpt4 key购买 nike

我正在通过 ARM 模板创建应用程序网关,引用 - Create Application Gateway v2我想为应用程序网关创建属性的多个实例,即上述模板中的“backendAddressPools”、“backendHttpSettingsCollection”等。无法通过“复制”创建多个实例。

尝试按照 - multipleinstances 中提供的示例实现,在 Azure DevOps 管道中执行时显示以下错误。

Unable to process template language expressions for resource '/subscriptions/XXXXXX/resourceGroups/rsgAppGw/providers/Microsoft.Network/applicationGateways/appGwV2' at line '1' and column '2537'. 'The template function 'copyIndex' is not expected at this location. The function can only be used in a resource with copy specified..

azuredeploy.json


{
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"virtualNetworkName": {
"type": "string",
"defaultValue": "Application-Vnet",
"metadata": {
"description": "Virtual Network name"
}
},
"vnetAddressPrefix": {
"type": "string",
"defaultValue": "10.0.0.0/16",
"metadata": {
"description": "Virtual Network address range"
}
},
"subnetName": {
"type": "string",
"defaultValue": "ApplicationGatewaySubnet",
"metadata": {
"description": "Name of the subnet"
}
},
"subnetPrefix": {
"type": "string",
"defaultValue": "10.0.0.0/24",
"metadata": {
"description": "Subnet address range"
}
},
"applicationGatewayName": {
"type": "string",
"defaultValue": "applicationGatewayV2",
"metadata": {
"description": "Application Gateway name"
}
},
"minCapacity": {
"type": "int",
"defaultValue": 2,
"metadata": {
"description": "Minimum instance count for Application Gateway"
}
},
"frontendPort": {
"type": "int",
"defaultValue": 80,
"metadata": {
"description": "Application Gateway Frontend port"
}
},
"backendPort": {
"type": "int",
"defaultValue": 80,
"metadata": {
"description": "Application gateway Backend port"
}
},
"backendAddressPools": {
"type": "array",
"defaultValue": "",
"metadata": {
"description": ""
}
},
"backendIPAddresses": {
"type": "array",
"metadata": {
"description": "Back end pool ip addresses"
}
},
"cookieBasedAffinity": {
"type": "string",
"allowedValues": ["Enabled", "Disabled"],
"defaultValue": "Disabled",
"metadata": {
"description": "Cookie based affinity"
}
},
"location": {
"type": "string",
"defaultValue": "[resourceGroup().location]",
"metadata": {
"description": "Location for all resources."
}
}
},
"variables": {
"appGwPublicIpName": "[concat(parameters('applicationGatewayName'), '-pip')]",
"appGwPublicIPRef": "[resourceId('Microsoft.Network/publicIPAddresses',variables('appGwPublicIpName'))]",
"appGwSize": "Standard_v2",
"subnetRef": "[resourceId('Microsoft.Network/virtualNetworks/subnets', parameters('virtualNetworkName'), parameters('subnetName'))]"
},
"resources": [
{
"apiVersion": "2018-08-01",
"type": "Microsoft.Network/virtualNetworks",
"name": "[parameters('virtualNetworkName')]",
"location": "[parameters('location')]",
"properties": {
"addressSpace": {
"addressPrefixes": ["[parameters('vnetAddressPrefix')]"]
},
"subnets": [
{
"name": "[parameters('subnetName')]",
"properties": {
"addressPrefix": "[parameters('subnetPrefix')]"
}
}
]
}
},
{
"apiVersion": "2018-08-01",
"type": "Microsoft.Network/publicIPAddresses",
"name": "[variables('appGwPublicIpName')]",
"location": "[parameters('location')]",
"sku": {
"name": "Standard"
},
"properties": {
"publicIPAllocationMethod": "Static"
}
},
{
"apiVersion": "2018-08-01",
"name": "[parameters('applicationGatewayName')]",
"type": "Microsoft.Network/applicationGateways",
"location": "[parameters('location')]",
"dependsOn": [
"[variables('appGwPublicIPRef')]",
"[concat('Microsoft.Network/virtualNetworks/', parameters('virtualNetworkName'))]"
],
"properties": {
"sku": {
"name": "[variables('appGwSize')]",
"tier": "Standard_v2"
},
"autoscaleConfiguration": {
"minCapacity": "[parameters('minCapacity')]"
},
"gatewayIPConfigurations": [
{
"name": "appGatewayIpConfig",
"properties": {
"subnet": {
"id": "[variables('subnetRef')]"
}
}
}
],
"frontendIPConfigurations": [
{
"name": "appGatewayFrontendIP",
"properties": {
"PublicIPAddress": {
"id": "[variables('appGwPublicIpRef')]"
}
}
}
],
"copy": [
{
"name": "frontendPorts",
"count": 1,
"input": {
"name": "appGatewayFrontendPort",
"properties": {
"Port": "[parameters('frontendPort')]"
}
}
},
{
"name": "backendAddressPools",
"count": "[length(parameters('backendAddressPools'))]",
"input": {
"name": "[parameters('backendAddressPools')[copyIndex('backendAddressPools')].name]"
},
"copy":{
"name":"copybackendIPAddresses",
"count":"[length(parameters('backendIPAddresses'))]",
"properties":{
"IpAddress":"[parameters('backendIPAddresses')[copyIndex('copybackendIPAddresses')].IpAddress]",
"fqdn":"[parameters('backendIPAddresses')[copyIndex('copybackendIPAddresses')].fqdn]"
}
}
},
{
"name": "backendHttpSettingsCollection",
"count": 1,
"input": {
"name": "appGatewayBackendHttpSettings",
"properties": {
"Port": "[parameters('backendPort')]",
"Protocol": "Http",
"CookieBasedAffinity": "[parameters('cookieBasedAffinity')]"
}
}
},
{
"name": "httpListeners",
"count": 1,
"input": {
"name": "appGatewayHttpListener",
"properties": {
"FrontendIpConfiguration": {
"Id": "[resourceId('Microsoft.Network/applicationGateways/frontendIPConfigurations', parameters('applicationGatewayName'), 'appGatewayFrontendIP')]"
},
"FrontendPort": {
"Id": "[resourceId('Microsoft.Network/applicationGateways/frontendPorts', parameters('applicationGatewayName'), 'appGatewayFrontendPort')]"
},
"Protocol": "Http"
}
}
},
{
"name": "requestRoutingRules",
"count": 1,
"input": {
"name": "rule1",
"properties": {
"RuleType": "Basic",
"httpListener": {
"id": "[resourceId('Microsoft.Network/applicationGateways/httpListeners', parameters('applicationGatewayName'), 'appGatewayHttpListener')]"
},
"backendAddressPool": {
"id": "[resourceId('Microsoft.Network/applicationGateways/backendAddressPools', parameters('applicationGatewayName'), 'appGatewayBackendPool')]"
},
"backendHttpSettings": {
"id": "[resourceId('Microsoft.Network/applicationGateways/backendHttpSettingsCollection', parameters('applicationGatewayName'), 'appGatewayBackendHttpSettings')]"
}
}
}
}
]
}
}
]
}

azuredeploy.parameters.json

{
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"virtualNetworkName": {
"value": "appGwVNet"
},
"vnetAddressPrefix": {
"value": "10.0.0.0/16"
},
"subnetName": {
"value": "appGwSubNet1"
},
"subnetPrefix": {
"value": "10.0.0.0/24"
},
"applicationGatewayName": {
"value": "appGwV2"
},
"minCapacity": {
"value": 1
},
"frontendPort": {
"value": 80
},
"backendPort": {
"value": 80
},
"backendAddressPools": {
"value": [
{
"name": "appGatewayBackendPool1"
},
{
"name": "appGatewayBackendPool2"
},
{
"name": "appGatewayBackendPool3"
}
]
},
"backendIPAddresses": {
"value": [
[
{
"IpAddress": "10.0.0.4"
},
{
"IpAddress": "10.0.0.5"
}
],
[
{
"IpAddress": "10.0.0.7"
},
{
"IpAddress": "10.0.0.8"
}
],
[
{
"fqdn": "mysite.com"
}
]
]
},
"cookieBasedAffinity": {
"value": "Disabled"
},
"location": {
"value": "centralus"
}
}
}


想要创建为应用程序网关提供的属性的多个实例。

最佳答案

这是我一直在做的一个例子:

{
"apiVersion": "2018-04-01",
"name": "[deployment().name]",
"type": "Microsoft.Network/applicationGateways",
"location": "[resourceGroup().location]",
"properties": {
"copy": [
{
"name": "backendAddressPools",
"count": "[length(parameters('backendAddressPools'))]",
"input": {
"name": "[parameters('backendAddressPools')[copyIndex('backendAddressPools')].name]",
"properties": "[parameters('backendIPAddresses')[copyIndex('backendAddressPools')]]"
}
}
]
}
}

这只是您需要适应您的需求的示例,但它展示了这个想法,您需要使用 properties 属性 (doh) 内的复制功能并定义您想要获得的内容。我已经为您定义了 backendAddressPools ,它应该或多或少地根据我认为您想要的功能工作(我可能是错的,所以可能需要在这里稍微修改一下)。

关于json - 如何通过 ARM 模板在应用程序网关中创建 backendAddressPools、frontendports 的多个实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56915823/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com