教程:创建和部署第一个 Azure 资源管理器 Bicep 文件

本教程介绍 Bicep。 其中将会说明如何创建初学者 Bicep 文件并将其部署到 Azure。 本教程还将介绍 Bicep 文件的结构,以及处理 Bicep 文件时所需的工具。 完成本教程大约需要 12 分钟,但实际时间根据需要安装的工具数量而异。

本文是相关教学系列的第一篇教程。 在学习该教程系列的过程中,你将逐步修改入门 Bicep 文件,直到了解了 Bicep 文件的所有核心部分。 这些元素是更复杂的 Bicep 文件的构建基块。 我们希望在本教程系列结束时,你能够自信地创建自己的 Bicep 文件,并准备好使用 Bicep 文件自动完成部署。

若要了解使用 Bicep 所带来的好处,以及为何要使用 Bicep 文件自动完成部署,请参阅 Bicep

如果没有 Azure 订阅,请在开始前创建一个试用版订阅

注意

本文包含 Bicep 示例。 Bicep 目前为预览版。 有关详细信息,请参阅 Bicep 项目

获取工具

首先,请确保已获取创建和部署 Bicep 文件所需的工具。 在本地计算机上安装这些工具。

编辑器

若要创建 Bicep 文件,需要一个很好的编辑器。 我们建议使用装有 Bicep 扩展的 Visual Studio Code。 如果需要安装这些工具,请参阅配置 Bicep 开发环境

命令行部署

你可以使用 Azure CLI 或 Azure PowerShell 来部署 Bicep 文件。 对于 Azure CLI,需要 2.20.0 或更高版本;对于 Azure PowerShell,需要 5.6.0 或更高版本。 有关安装说明,请参阅:

安装 Azure PowerShell 或 Azure CLI 后,请务必完成首次登录。 有关帮助,请参阅登录 - PowerShell登录 - Azure CLI

好了,现在可以开始了解 Bicep。

创建第一个 Bicep 文件

  1. 打开装有 Bicep 扩展的 Visual Studio Code。

  2. 在“文件”菜单中,选择“新建文件”以创建新的文件。

  3. 在“文件”菜单中选择“另存为”。

  4. 将文件命名为 azuredeploy,并选择 bicep 文件扩展名。 完整的文件名为 azuredeploy.bicep

  5. 将该文件保存到工作站。 选择容易记住的路径,因为稍后在部署 Bicep 文件时需要提供该路径。

  6. 将以下内容复制并粘贴到该文件中:

    resource stg 'Microsoft.Storage/storageAccounts@2019-06-01' = {
      name: '{provide-unique-name}'  // must be globally unique
      location: 'chinaeast'
      sku: {
        name: 'Standard_LRS'
      }
      kind: 'StorageV2'
      properties: {
        supportsHttpsTrafficOnly: true
      }
    }
    

    Visual Studio Code 环境如下所示:

    Visual Studio Code - 第一个 Bicep 文件

    资源声明具有四个组件:

    • 资源:关键字。

    • 符号名称 (stg):符号名称是用于在整个 bicep 文件中引用资源的标识符。 它不是在部署资源时的资源名称。 资源名称由 name 属性定义。 请参阅此列表中的第四个组件。 为使教程易于理解,在本教程系列中,我们将 stg 用作存储帐户资源的符号名称。 若要查看如何使用符号名称获取对象属性的完整列表,请参阅添加输出

    • 资源类型 (Microsoft.Storage/storageAccounts@2019-06-01):它包括资源提供程序 (Microsoft.Storage)、资源类型 (storageAccounts) 和 apiVersion (2019-06-01)。 每个资源提供程序都发布了其自身的 API 版本,因此此值与特定的类型相关。

    • 属性(= {...} 内部的任何内容):要为给定的资源类型指定的特定属性。 这些属性与 ARM 模板中提供的属性完全相同。 每个资源都有一个 name 属性。 大多数资源还有一个 location 属性,该属性用于设置资源部署到的区域。 其他属性因资源类型和 API 版本而异。 了解 API 版本与可用属性之间的关联非常重要,因此,让我们直接了解详情。

      对于此存储帐户,可以在 storageAccounts 2019-06-01 中看到 API 版本。 请注意,你并未将所有属性添加到 Bicep 文件。 许多属性是可选的。 Microsoft.Storage 资源提供程序可能发布了新的 API 版本,但要部署的版本不需要更改。 可以继续使用该版本,部署的结果是一致的。

      如果查看较旧的 API 版本(例如 storageAccounts 2016-05-01),你会发现提供了一个较小的属性集。

      如果你决定更改资源的 API 版本,请确保评估该版本的属性,并相应地调整 Bicep 文件。

    有关详细信息,请参阅 Bicep 结构

    名称属性有一个注释。 将 // 用于单行注释或将 /* ... */ 用于多行注释

  7. {provide-unique-name}(包括大括号 {})替换为唯一的存储帐户名称。

    重要

    存储帐户名称在 Azure 中必须是唯一的。 该名称只能包含小写字母或数字。 其长度不能超过 24 个字符。 可以尝试使用某种命名模式,例如,使用 store1 作为前缀,然后添加你的姓名首字母缩写和当天的日期。 例如,使用的名称类似于 store1abc09092019

    存储帐户的唯一名称不容易猜出,尤其是在大型部署的自动化中不太适合进行这种猜测。 稍后在本教程系列中,你将使用 Bicep 功能来更轻松地创建唯一名称。

  8. 保存文件。

祝贺你,现已创建第一个 Bicep 文件。

登录 Azure

若要开始使用 Azure PowerShell/Azure CLI,请使用你的 Azure 凭据登录。

使用以下代码部分中的选项卡在 Azure PowerShell 与 Azure CLI 之间进行选择。 本文中的 CLI 示例针对 Bash shell 编写。

注意

在可以在由世纪互联运营的 Microsoft Azure 中使用 Azure CLI 之前,请先运行 az cloud set -n AzureChinaCloud 来更改云环境。 若要切换回 Azure 公有云,请再次运行 az cloud set -n AzureCloud

Connect-AzAccount -Environment AzureChinaCloud

如果你有多个 Azure 订阅,请选择要使用的订阅。 将 [SubscriptionID/SubscriptionName] 和方括号 [] 替换为你的订阅信息:

Set-AzContext [SubscriptionID/SubscriptionName]

创建资源组

部署 Bicep 文件时,请指定一个包含资源的资源组。 在运行部署命令之前,请使用 Azure CLI 或 Azure PowerShell 创建该资源组。

New-AzResourceGroup `
  -Name myResourceGroup `
  -Location "China North"

部署 Bicep 文件

Bicep 是基于 Azure 资源管理器模板(ARM 模板)的透明抽象。 在部署每个 Bicep 文件之前,需将该文件编译成标准的 ARM 模板。 可以在部署 Bicep 文件之前将其编译成 ARM 模板,也可以直接部署 Bicep 文件。 若要部署 Bicep 文件,请使用 Azure CLI 或 Azure PowerShell。 使用创建的资源组。 为部署指定一个适当的名称,以便可以在部署历史记录中轻松识别该部署。 为方便起见,另请创建一个用于存储 Bicep 文件路径的变量。 此变量使你能够更轻松地运行部署命令,因为无需在每次部署时都重新键入路径。 将 {provide-the-path-to-the-bicep-file}(包括大括号 {})替换成扩展名为 .bicep 的 Bicep 文件的路径。

若要运行此部署 cmdlet,你必须具有 Azure PowerShell 的最新版本

$bicepFile = "{provide-the-path-to-the-bicep-file}"
New-AzResourceGroupDeployment `
  -Name firstbicep `
  -ResourceGroupName myResourceGroup `
  -TemplateFile $bicepFile

部署命令将返回结果。 查看 ProvisioningState 以确定部署是否成功。

注意

如果部署失败,请使用 verbose 开关获取有关正在创建的资源的信息。 使用 debug 开关获取调试的详细信息。

验证部署

可以通过在 Azure 门户中浏览资源组来验证部署。

  1. 登录 Azure 门户

  2. 在左侧菜单中选择“资源组”。

  3. 选择在上一过程中部署的资源组。 默认名称为 myResourceGroup。 你应会看到,该资源组中未部署任何资源。

  4. 请注意,在概述的右上角显示了部署状态。 选择“1 成功”。

    查看部署状态

  5. 将会看到该资源组的部署历史记录。 选择“firstbicep”。

    选择部署

  6. 将会看到部署摘要。 已部署了一个存储帐户。 请注意,在左侧可以查看部署过程中使用的输入、输出和模板。

    查看部署摘要

清理资源

若要继续学习下一篇教程,则不需删除该资源组。

如果就此停止学习,请删除该资源组。

  1. 在 Azure 门户上的左侧菜单中选择“资源组” 。
  2. 在“按名称筛选”字段中输入资源组名称。
  3. 选择资源组名称。
  4. 在顶部菜单中选择“删除资源组”。

后续步骤

现已创建一个要部署到 Azure 的简单 Bicep 文件。 后续教程会介绍如何将参数、变量、输出和模块添加到 Bicep 文件。 这些功能是更复杂的 Bicep 文件的构建基块。