Ansible:"unknown type long" 在 Azure 中更新私有 DNS 区域时

Ansible: "unknown type long" when updating Private DNS Zone in Azure

我尝试更新 Azure 私有 DNS 中某个区域的序列号。为此,我 运行 Ansible 代码:

- name: Increment DNS serial
  azure_rm_dnsrecordset:
    resource_group: "{{ my_rg }}"
    zone_name: "{{ my_domain }}"
    relative_name: "@"
    record_type: "SOA"
    records:
      - serial_number: "{{ new_serial }}"
  register: dns_update
  until: dns_update is succeeded      

然而 Ansible 因类型不匹配错误而失败:

The full traceback is:
fatal: [localhost]: FAILED! => {
    "changed": false,
    "invocation": {
        "module_args": {
            ...
            "record_mode": "purge",
            "record_type": "SOA",
            "records": [
                {
                    "serial_number": "2"
                }
            ],
            "relative_name": "@",
            "resource_group": "my-rg",
            "state": "present",
            ...
        }
    },
    "msg": "implementation error: unknown type long requested for serial_number"
}

错误消息有点令人困惑:我应该将其理解为 Ansible 尝试发送 2,而 Azure API 需要字符串,反之亦然,Azure 需要很长但 Ansible 发送字符串?

我应该应用哪种类型转换?

除了上述问题,这是更新序列号的正确方法吗?

我通过从 azure_rm_dnsrecordset Ansible 模块切换到 az 调用来绕过这个,替换模板如下:

- name: Increment DNS serial
  command: >
    az network private-dns record-set soa update
    --resource-group "{{ my_rg }}"
    --zone-name "{{ my_domain }}"
    --serial-number "{{ new_serial }}"

这至少被 Azure 接受了。

但是它不会为我更新序列号。我可以更新其他 SOA 参数,例如刷新时间或最小 TTL,但不能更新序列号;但这是不同的问题。