如何在 Azure ARM 模板中创建新资源?

How to create a new resource in Azure ARM templates?

好的,我已经使用 ARM 模板完成了此处描述的所有操作 - https://azure.microsoft.com/en-us/documentation/articles/web-sites-integrate-with-vnet。除了一件事 - 启用 VNET 与预先存在的 VNET 的集成。

这可以在 ARM 模板中完成吗? 谢谢!

这是一个可能对您有所帮助的示例模板。它修改自 this quickstart sample in GitHub

{
   "$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
   "contentVersion": "1.0.0.0",
   "parameters": {
      "hostingPlanName": {
         "type": "string",
         "minLength": 1,
         "metadata": {
            "description": "Name of the hosting plan to use in Azure."
         }
      },
      "webSiteName": {
         "type": "string",
         "minLength": 1,
         "metadata": {
            "description": "Name of the Azure Web app to create."
         }
      },
      "vnetName": {
         "type": "string",
         "minLength": 1,
         "metadata": {
            "description": "Name of an existing Azure VNet which has a Gateway Subnet already, and is in the resource group you are going to deploy."
         }
      },
      "skuName": {
         "type": "string",
         "defaultValue": "S1",
         "allowedValues": [
            "S1",
            "S2",
            "S3",
            "P1",
            "P2",
            "P3",
            "P4"
         ],
         "metadata": {
            "description": "Describes plan's pricing tier and instance size. Check details at https://azure.microsoft.com/en-us/pricing/details/app-service/"
         }
      },
      "skuCapacity": {
         "type": "int",
         "defaultValue": 1,
         "minValue": 1,
         "metadata": {
            "description": "Describes plan's instance count"
         }
      }
   },
   "resources": [
      {
         "apiVersion": "2015-08-01",
         "name": "[parameters('hostingPlanName')]",
         "type": "Microsoft.Web/serverfarms",
         "location": "[resourceGroup().location]",
         "tags": {
            "displayName": "HostingPlan"
         },
         "sku": {
            "name": "[parameters('skuName')]",
            "capacity": "[parameters('skuCapacity')]"
         },
         "properties": {
            "name": "[parameters('hostingPlanName')]"
         }
      },
      {
         "apiVersion": "2015-08-01",
         "name": "[parameters('webSiteName')]",
         "type": "Microsoft.Web/sites",
         "location": "[resourceGroup().location]",
         "tags": {
            "[concat('hidden-related:', resourceGroup().id, '/providers/Microsoft.Web/serverfarms/', parameters('hostingPlanName'))]": "Resource",
            "displayName": "Website"
         },
         "dependsOn": [
            "[concat('Microsoft.Web/serverfarms/', parameters('hostingPlanName'))]"
         ],
         "properties": {
            "name": "[parameters('webSiteName')]",
            "serverFarmId": "[resourceId('Microsoft.Web/serverfarms', parameters('hostingPlanName'))]"
         },
         "resources": [
            {
               "apiVersion": "2015-08-01",
               "name": "web",
               "type": "config",
               "dependsOn": [
                  "[concat('Microsoft.Web/sites/', parameters('webSiteName'))]"
               ],
               "properties": {
                  "pythonVersion": "3.4"
               }
            },
            {
              "apiVersion": "2015-08-01",
              "name": "[parameters('vnetName')]",
              "type": "virtualNetworkConnections",
              "location": "[resourceGroup().location]",
              "dependsOn": [
                  "[concat('Microsoft.Web/sites/', parameters('webSiteName'))]"
              ],
              "properties": {
                  "vnetResourceId": "[concat(resourceGroup().id, '/providers/Microsoft.Network/virtualNetworks/', parameters('vnetName'))]"
              }
            }
         ]
      }
   ]
}

以下是您应该注意的 3 件事。

  1. 该模板以 python 网络应用程序模板开始,并添加了 "Microsoft.Web/sites/virtualNetworkConnections" 资源。所以,如果您使用其他编程语言,您可以从其他模板开始。

  2. 预先存在的 VNet 应该在您正在部署的同一个资源组中。如果你使用的VNet不在同一个资源组,你应该修改"Microsoft.Web/sites/virtualNetworkConnections"的"properties"中的"vnetResourceId"。

  3. 您正在使用的 VNet 应该已经有一个带有点到站点地址的网关。否则,您将无法将 Web 应用集成到 VNet。有关详细信息,请参阅 Configure a Point-to-Site connection to a virtual network using PowerShell

更新:关于我是如何得到这个信息的,嗯,网上没有太多关于这个的信息。这个模板是基于 PowerShell 解决方案和我对 ARM 模板的了解构建的。 PowerShell 解决方案在 this article 中可用。获取 ARM 模板的另一种可能方法是在一个资源组中创建这些资源,然后在门户中导出资源组的模板。但是,对于这种情况,这是行不通的,因为资源类型 "Microsoft.Web/sites/virtualNetworkConnections" 还不受支持。但是,您仍然可以通过带有选项 -debug.

的 PowerShell 命令 Get-AzureRmResource 查看 REST API
Get-AzureRmResource -ResourceGroupName <resource group> -ResourceType Microsoft.Web/sites/virtualNetworkConnections -Name <web app>/<VNet> -debug -ApiVersion 2015-08-01

您将获得以下 REST API。

URI:

https://management.azure.com/subscriptions/<subscription id>/resourceGroups/<resource group>/providers/Microsoft.Web/sites/<web app>/virtualNetworkConnections/<VNet>?api-version=2015-08-01

正文:

{
  "id": "/subscriptions/<subscription id>/resourceGroups/<resource group>/providers/Microsoft.Web/sites/<web app>/virtualNetworkConnections/<VNet>",
  "name": "<VNet>",
  "type": "Microsoft.Web/sites/virtualNetworkConnections",
  "location": "<Location>",
  "tags": null,
  "properties": {
    "vnetResourceId": "/subscriptions/<subscription id>/resourceGroups/<resource group>/providers/Microsoft.Network/virtualNetworks/<VNet>"
    "certThumbprint": "<Thumbprint>",
    "certBlob": "<cert>",
    "routes": null,
    "resyncRequired": false,
    "dnsServers": null
  }
}

跳过一些自动生成的值,你会得到与我写的非常相似的模板:

{
  "name": "<VNet>",
  "type": "Microsoft.Web/sites/virtualNetworkConnections",
  "location": "<Location>",
  "properties": {
    "vnetResourceId": "/subscriptions/<subscription id>/resourceGroups/<resource group>/providers/Microsoft.Network/virtualNetworks/<VNet>"
  }
}