Bicep 是一种用于声明式部署Azure资源的领域特定语言。它的目标是通过更清晰的语法、改进的类型安全性、以及对模块化和代码重用的更好支持,彻底简化编写体验。
Bicep 其实是对 ARM 模板的透明抽象,Bicep代码被解析成标准的 JSON 文件,它有效地将 ARM模板 视为一种中间语言(IL)。Bicep 不是编写应用程序的通用编程语言,而是声明Azure资源和资源属性的语言。简单来说,它是用来开发 Azure ARM 模板的。
Azure Bicep 文档:https://docs.microsoft.com/zh-cn/azure/azure-resource-manager/bicep/overview
Bicep 文档:https://github.com/Azure/bicep
(1)VS Code 编辑器安装 Bicep 插件

(2)安装 Bicep CLI
1) 利用 Azure CLI 手动安装
az bicep install

2) 利用 Chocolatey 手动安装
choco install bicep

在Bicep项目目录下创建后缀为 bicep 的 main 文件,这个时候会下载.NET runtime ,稍等片刻。

Azure资源的声明还是从最熟悉的资源组开始,在 “main.bicep” 文件中中输入 “res-rg” ,并按Tab 补全代码。添加Scope作用域,如下图所示
targetScope=‘subscription‘
resource rg ‘Microsoft.Resources/resourceGroups@2021-04-01‘ = {
name: ‘Web_Test_Bicep_RG‘
location: ‘EastAsia‘
tags:{
‘tag‘: ‘create by bicep‘
}
}
当前代码中标记为红色的为自定义值。
点击图中箭头指向,可以以可视化的方式查看资源依赖关系

在部署 Bicep 文件之前,可以预测即将发生的资源更改。 此时我们需要添加在CLI 命令中加入 what-if,方便我们查看不同类型资源的更改。
az deployment sub what-if --location "eastasia" --template-file "main.bicep"

Bicep 能定义将资源部署到设定目标有 “资源组”,“订阅”,“管理组”,“租户”
本文中演示是将 “Web_Test_Rg” 部署到 “订阅”
az deployment sub create --confirm-with-what-if --location "eastasia" --template-file "main.bicep"

查看资源组部署状况

通过本篇文章介绍的 Bicep 语法的使用来看确实不需要写太多的参数设置,要比 JSON 语法更简单。更为我们在选择基础设施即代码的解决方案上又增加了新的方案。
原文:https://www.cnblogs.com/AllenMaster/p/15157355.html