如何使用 ARM 模板将 Azure DNS A 记录替换为 CNAME 记录

问题描述

我正在尝试使用 ARM 模板将现有的 DNS A 记录替换为具有相同名称的 CNAME 记录。我在 DNS 区域中有一条记录,如下所示

  • 名称 - 我的链接
  • 值 - 10.22.31.3
  • 类型 - A
  • TTL - 60

我想在同一个 DNS 区域中有 CNAME 记录,应该如下所示

  • 名称 - 我的链接
  • 值 - cos.myaddress.test.net
  • 类型 - CNAME
  • TTL - 60

目前我的 ARM 模板看起来像下面创建 A 记录

{
  "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion": "1.0.0.0","parameters": {},"resources": [
    {
      "type": "Microsoft.Network/dnszones/A","apiVersion": "2018-05-01","name": "mylink","properties": {
        "TTL": 60,"ARecords": [
          {
            "ipv4Address": "10.22.31.3"
          }
        ]
      }
    },]
}

我尝试向此模板添加一个 CNAME 记录,但在部署时出错。

"code": "冲突",

"message": "无法创建 CNAME 记录,因为此区域中已存在另一条同名记录。"

解决方法

如显示的错误,我们无法创建与同一区域中现有记录集相同的CNAME记录名,因为CNAME记录集不能与其他同名记录集共存。参考here

因此,在这种情况下,我们需要删除旧的 A 记录或使用不同的记录名称创建 CNAME 记录。

使用 ARM 模板部署资源时,您指定部署是增量更新或完整更新。默认情况下,部署使用增量模式。您可以考虑使用 complete mode 删除资源组中存在但未在模板中指定的资源。

但是,像dnszones / *这样的子资源类型不支持完全模式删除。 enter image description here

总而言之,我们不能使用 ARM 模板直接将 Azure DNS A 记录替换为 CNAME 记录。我们需要先使用 Azure 门户或其他 cmdlet 删除 A 记录,然后照常使用 ARM 模板创建 CNAME 记录。