练习 - 更新管道的触发器

已完成

同事要求你在公司网站上启用应用服务 AlwaysOn 功能,以便网站应用始终运行。

在本练习中,你将更新创建的管道,使其在主分支上的文件发生更改时自动运行。 你将使用更新的管道将请求的配置更改部署到网站。

在此过程中,你将:

  • 更新管道,使其在 deploy 文件夹和主分支中的文件发生更改时自动触发。
  • 对 Bicep 文件进行更改。
  • 验证管道是否自动运行。

将触发器更新为基于分支

  1. 在 Visual Studio Code 中,打开 deploy/azure-pipelines.yml 文件。

  2. 删除第一行中的手动触发器。

  3. 在第一行上添加以下触发器定义:

    trigger:
      batch: true
      branches:
        include:
        - main
    

    请注意,你还启用并发控制,以避免管道同时运行多次。

  4. 保存对该文件所做的更改。

  5. 提交所做的更改,但先不要推送更改。 很快就会推送这些更改。

    git add .
    git commit -m 'Add branch trigger'
    

更新 Bicep 文件

  1. 在 Visual Studio Code 中,打开 main.bicep 文件。

  2. appServiceApp 资源定义的 siteConfig 属性中,添加值为 truealwaysOn 属性:

    resource appServiceApp 'Microsoft.Web/sites@2022-03-01' = {
      name: appServiceAppName
      location: location
      properties: {
        serverFarmId: appServicePlan.id
        httpsOnly: true
        siteConfig: {
          alwaysOn: true
          appSettings: [
            {
              name: 'ToyManualsStorageAccountConnectionString'
              value: toyManualsStorageAccountConnectionString
            }
          ]
        }
      }
    }
    
  3. 保存对该文件所做的更改。

  4. 在 Visual Studio Code 终端中,运行以下命令来提交更改并推送两个提交:

    git add .
    git commit -m 'Configure app Always On setting'
    git push
    

验证管道是否失败

  1. 在浏览器中,选择“管道”,然后选择“创建管道”。

  2. 选择最近的运行,以查看管道是否自动运行。 管道运行是因为你将更改推送到了分支触发器监视的分支。 如果管道仍在运行,请稍等片刻,然后刷新页面。

    显示失败的管道运行的 Azure DevOps 屏幕截图。

    管道显示失败的部署。

  3. 若要诊断失败,请在“作业”中选择作业,然后选择失败的 AzureResourceManagerTemplateDeployment 任务。 滚动以查看完整的错误消息。 错误消息包含以下文本:

    There was a conflict. AlwaysOn cannot be set for this site as the plan does not allow it. For more information on pricing and features, please see: https://aka.ms/appservicepricingdetails

    此错误消息表明部署失败,因为应用服务应用是使用不支持 Always On 功能的 F1 免费层部署的。

    重要

    此示例说明了测试 Bicep 文件(包括所使用的所有参数值)的重要性。 细微的错误很容易添加到资源配置或其他代码中。 在管道部署代码之前,可能无法发现问题,从而导致失败。 在将来的模块中,你将了解一些可用于验证和测试 Bicep 代码的策略。

修复 Bicep 文件并再次查看已触发的管道

你与同事讨论了失败的部署。 你们共同决定只需要将 Always On 设置应用于生产环境。 此处通过应用你决定使用的新规则来解决导致部署失败的问题。

  1. 在 Visual Studio Code 中,将每种环境类型的新属性添加到 environmentConfigurationMap 变量:

    var environmentConfigurationMap = {
      nonprod: {
        appServiceApp: {
          alwaysOn: false
        }
        appServicePlan: {
          sku: {
            name: 'F1'
            capacity: 1
          }
        }
        toyManualsStorageAccount: {
          sku: {
            name: 'Standard_LRS'
          }
        }
      }
      prod: {
        appServiceApp: {
          alwaysOn: true
        }
        appServicePlan: {
          sku: {
            name: 'S1'
            capacity: 2
          }
        }
        toyManualsStorageAccount: {
          sku: {
            name: 'Standard_ZRS'
          }
        }
      }
    }
    
  2. 更改应用程序的 alwaysOn 设置以使用适合环境类型的配置映射值:

    resource appServiceApp 'Microsoft.Web/sites@2022-03-01' = {
      name: appServiceAppName
      location: location
      properties: {
        serverFarmId: appServicePlan.id
        httpsOnly: true
        siteConfig: {
          alwaysOn: environmentConfigurationMap[environmentType].appServiceApp.alwaysOn
          appSettings: [
            {
              name: 'ToyManualsStorageAccountConnectionString'
              value: toyManualsStorageAccountConnectionString
            }
          ]
        }
      }
    }
    
  3. 保存对该文件所做的更改。

  4. 在 Visual Studio Code 终端中,提交更改并推送它们:

    git add .
    git commit -m 'Enable App Service Always On for production environments only'
    git push
    

验证管道是否成功

  1. 在 Azure DevOps 中,返回到“管道”列表,并选择管道。

  2. 选择最近的运行。 如果管道仍在运行,请稍等片刻,然后刷新页面。

    显示成功的管道运行的 Azure DevOps 屏幕截图。

    管道显示成功的部署。 这次成功是因为使用了有效的 Bicep 文件。

清理资源

完成练习后,可以删除资源,以便不再为这些资源付费。

在 Visual Studio Code 终端中,运行以下命令:

az group delete --resource-group ToyWebsite --yes --no-wait

资源组将在后台删除。

Remove-AzResourceGroup -Name ToyWebsite -Force