0

我在部署ARM模板时遇到奇怪的行为。ARM模板包含Web应用程序的配置设置

我有以下模板:(注意sasUrl值“XXX”在我的文件有一个真实的,工作值)

{ 
    "name": "[variables('webAppServiceName')]", 
    "type": "Microsoft.Web/sites", 
    "location": "[resourceGroup().location]", 
    "apiVersion": "2016-08-01", 
    "dependsOn": [ 
    "[concat('Microsoft.Web/serverfarms/', variables('appServicePlanName'))]" 
    ], 
    "tags": { 
    "[concat('hidden-related:', resourceGroup().id, '/providers/Microsoft.Web/serverfarms/', variables('appServicePlanName'))]": "Resource", 
    "displayName": "[variables('webAppServiceName')]" 
    }, 
    "properties": { 
    "name": "[variables('webAppServiceName')]", 
    "serverFarmId": "[resourceId('Microsoft.Web/serverfarms', variables('appServicePlanName'))]" 
    }, 
    "resources": [ 
    { 
     "apiVersion": "2014-11-01", 
     "name": "appsettings", 
     "type": "config", 
     "dependsOn": [ 
     "[concat('Microsoft.Web/sites/', variables('webAppServiceName'))]", 
     "[concat('Microsoft.Web/certificates/', variables('certificateName'))]" 
     ], 
     "tags": { 
     "displayName": "WebAppSettings" 
     }, 
     "properties": { 
     "WEBSITE_LOAD_CERTIFICATES": "[reference(resourceId('Microsoft.Web/certificates', variables('certificateName')), providers('Microsoft.Web', 'certificates').apiVersions[0]).thumbprint]" 
     } 
    }, 
    { 
     "apiVersion": "2016-08-01", 
     "name": "Microsoft.ApplicationInsights.Profiler.AzureWebApps", 
     "type": "siteextensions", 
     "dependsOn": [ 
     "[resourceId('Microsoft.Web/Sites', variables('webAppServiceName'))]" 
     ], 
     "properties": {} 
    }, 
    { 
     "apiVersion": "2015-08-01", 
     "name": "logs", 
     "type": "config", 
     "dependsOn": [ 
     "[resourceId('Microsoft.Web/Sites', variables('webAppServiceName'))]" 
     ], 
     "properties": { 
     "applicationLogs": { 
      "fileSystem": { 
      "level": "Off" 
      }, 
      "azureTableStorage": { 
      "level": "Off" 
      }, 
      "azureBlobStorage": { 
      "level": "[parameters('applicationLogLevel')]", 
      "sasUrl": "xxx" 
      } 
     }, 
     "httpLogs": { 
      "fileSystem": { 
      "enabled": false 
      }, 
      "azureBlobStorage": { 
      "enabled": true, 
      "sasUrl": "xxx" 
      } 
     }, 
     "failedRequestsTracing": { 
      "enabled": "[parameters('enableFailedRequestTracing')]" 
     }, 
     "detailedErrorMessages": { 
      "enabled": "[parameters('enableDetailedErrorMessages')]" 
     } 
     } 
    } 
    ] 
} 

当部署,而无需修改任何此模板,在配置部分中的“日志”是没有正确部署+ - 1次2次。我刚刚再次测试了ARM模板,并且第一次部署时,Web应用程序没有正确的诊断日志记录设置。这是第二次,但第三次他们没事。但第四次,设置不再正确。它看起来像这个模板的一部分没有一致的行为。

我在监督什么吗?

+0

你有关于这个主题的任何更新?如果它有用,请帮助将其标记为答案,以帮助更多具有相同问题的社区? –

+0

我仍然没有一致的结果,但支持凭单已记录在Azure支持团队中,他们正在处理它。 – Identity

回答

0

我尝试使用appsetting和logs创建WebApp,它对我来说工作正常。我使用Visual Studio创建了该项目。以下是我的详细步骤。

1.创建Azure的资源项目

enter image description here

2.Select的Web应用程序模板

enter image description here

3.Click部署文件,然后右键点击并删除不必要的资源

enter image description here

4.增加了Appsetting资源的Web应用程序

enter image description here

5.Add为Azure的Web应用程序

{ 
      "apiVersion": "2015-08-01", 
      "name": "logs", 
      "type": "config", 
      "dependsOn": [ 
      "[resourceId('Microsoft.Web/Sites', variables('webSiteName'))]" 
      ], 
      "properties": { 
      "applicationLogs": { 
       "fileSystem": { 
       "level": "Off" 
       }, 
       "azureTableStorage": { 
       "level": "Off" 
       }, 
       "azureBlobStorage": { 
       "level": "[variables('Level')]", 
       "sasUrl": "xxxx" 
       } 
      }, 
      "httpLogs": { 
       "fileSystem": { 
       "enabled": false 
       }, 
       "azureBlobStorage": { 
       "enabled": true, 
       "sasUrl": "xxxxxx" 
       } 
      }, 
      "failedRequestsTracing": { 
       "enabled": "[parameters('enableFailedRequestTracing')]" 
      }, 
      "detailedErrorMessages": { 
       "enabled": "[parameters('enableDetailedErrorMessages')]" 
      } 
      } 
     } 

日志代码6.Right单击该项目,并选择部署

enter image description here

7.检查第Ë输出和Azure的门户

enter image description here

enter image description here

整条手臂的模板:

{ 
    "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", 
    "contentVersion": "1.0.0.0", 
    "parameters": { 
    "hostingPlanName": { 
     "type": "string", 
     "minLength": 1 
    }, 
    "enableFailedRequestTracing": { 
     "type": "bool" 
    }, 
    "enableDetailedErrorMessages": { 
     "type": "bool" 
    }, 
    "skuName": { 
     "type": "string", 
     "defaultValue": "F1", 
     "allowedValues": [ 
     "F1", 
     "D1", 
     "B1", 
     "B2", 
     "B3", 
     "S1", 
     "S2", 
     "S3", 
     "P1", 
     "P2", 
     "P3", 
     "P4" 
     ], 
     "metadata": { 
     "description": "Describes plan's pricing tier and capacity. 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" 
     } 
    } 
    }, 
    "variables": { 
    "webSiteName": "[concat('webSite', uniqueString(resourceGroup().id))]", 
    "Level": "Error" 
    }, 
    "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": "[variables('webSiteName')]", 
     "type": "Microsoft.Web/sites", 
     "location": "[resourceGroup().location]", 
     "tags": { 
     "[concat('hidden-related:', resourceGroup().id, '/providers/Microsoft.Web/serverfarms/', parameters('hostingPlanName'))]": "Resource", 
     "displayName": "Website" 
     }, 
     "dependsOn": [ 
     "[resourceId('Microsoft.Web/serverfarms/', parameters('hostingPlanName'))]" 
     ], 
     "properties": { 
     "name": "[variables('webSiteName')]", 
     "serverFarmId": "[resourceId('Microsoft.Web/serverfarms', parameters('hostingPlanName'))]" 
     }, 
     "resources": [ 
     { 
      "name": "appsettings", 
      "type": "config", 
      "apiVersion": "2015-08-01", 
      "dependsOn": [ 
      "[resourceId('Microsoft.Web/sites', variables('webSiteName'))]" 
      ], 
      "tags": { 
      "displayName": "appsettings" 
      }, 
      "properties": { 
      "key1": "value1", 
      "key2": "value2" 
      } 
     }, 
     { 
      "apiVersion": "2015-08-01", 
      "name": "logs", 
      "type": "config", 
      "dependsOn": [ 
      "[resourceId('Microsoft.Web/Sites', variables('webSiteName'))]" 
      ], 
      "properties": { 
      "applicationLogs": { 
       "fileSystem": { 
       "level": "Off" 
       }, 
       "azureTableStorage": { 
       "level": "Off" 
       }, 
       "azureBlobStorage": { 
       "level": "[variables('Level')]", 
       "sasUrl": "xxxxx" 
       } 
      }, 
      "httpLogs": { 
       "fileSystem": { 
       "enabled": false 
       }, 
       "azureBlobStorage": { 
       "enabled": true, 
       "sasUrl": "xxxx" 
       } 
      }, 
      "failedRequestsTracing": { 
       "enabled": "[parameters('enableFailedRequestTracing')]" 
      }, 
      "detailedErrorMessages": { 
       "enabled": "[parameters('enableDetailedErrorMessages')]" 
      } 
      } 
     } 
     ] 
    } 

    ] 
} 
+0

感谢您的回复。多次重新部署模板时会得到一致的结果吗?有时它对我有用,有时在使用完全相同的模板和参数文件时会错误配置日志设置。 – Identity

+0

我试了3次,都为我工作。 –

+0

@ TomSun-MSFT在本示例中提到了sasurl:“xxx”。如何在创建存储帐户后使用ARM模板获取sasurl? – vengi83644

相关问题