如何为Google Cloud DNS区域设置默认名称服务器?

问题描述

我正在使用Google的CloudDNS API将一批域批量上传到Google Cloud。我希望能够覆盖Google随机分配的名称服务器,例如

  • ns-cloud-e1.google.com
  • ns-cloud-e2.google.com
  • ns-cloud-e3.google.com
  • ns-cloud-e4.google.com

  • n1.domain.com
  • n2.domain.com
  • n3.domain.com

我注意到Google的CloudDNS api文档参考了以下内容

nameServerSet (字符串)-

(可选)为此ManagedZone指定NameServerSet。一种 NameServerSet是一组都承载相同名称的DNS名称服务器 ManagedZones。大多数用户会将此字段保留为未设置状态。

尽管通过CloudDNS尝试使用此属性时,我从API收到响应,说通过数据提供的数据无效。我以"n1.domain.com.,n2.domain.com.,n3.domain.com."的格式通过。我也尝试过传递一组名称服务器和Google PHP包中的RecordResourceSet类,但无济于事。

这是我应该遵循的正确格式吗?或者在创建托管区域时不能预定义名称服务器,而是在创建区域后必须这样做吗?

下面的代码示例,$ cloud_dns-> service是Google_Service_Dns的实例

$cloud_dns->service->managedZones
    ->create(
         'blah',new Google_Service_Dns_ManagedZone([
             'dnsName'       => $dns_name_formatted,'name'          => 'app-' . $domain_name,'description'   => 'Batch Uploaded Domain','nameServerSet' => 'n1.domain.com.,n3.domain.com.'
           ]),);

解决方法

您不妨考虑向Google的公众Issue Tracker提交此问题。

您不是first遇到此问题的人,这个问题已有4年历史了,仍然没有得到解答:-(

无论使用哪种语言SDK,都可以使用Google的APIs Explorer(尤其是ManagedZones:create)来测试基础调用,该调用方便地包含了相关的API方法。您可以插入您的值并在浏览器中尝试(安全地),或者:

NAME="yourdomain-com"
DNS="yourdomain.com." # Must end with a period (.)

TOKEN=$(gcloud auth print-access-token)

curl \
--request POST \
--header "Authorization: Bearer ${TOKEN}" \
--header "Accept: application/json" \
--header "Content-Type: application/json" \
--data "{\"nameServerSet\":\"n1.domain.com.,n2.domain.com.\",\"name\":\"${NAME}\",\"dnsName\":\"${DNS}\",\"description\":\"\"}" \
"https://dns.googleapis.com/dns/v1/projects/${PROJECT}/managedZones"

我尝试直接使用API​​使用nameServerSet来创建请求,但无法执行。因此,这不是语言SDK的问题,而是有关如何设置此属性的问题。

值得注意的是,通过控制台(link)创建区域时不能设置名称服务器。但是,您可以随后更改它们。控制台POST至ManagedZone:changes,例如:

POST https://www.googleapis.com/dns/v1beta2/projects/${PROJECT}/managedZones/${NAME}/changes
{
  "additions": [
    {
      "name": "...","type": "NS","ttl": 21600,"rrdatas": [
        "ns-cloud-d1.googledomains.com.","ns-cloud-d3.googledomains.com.","ns-cloud-d4.googledomains.com."
      ]
    }
  ],"deletions": [
    {
      "name": "...","rrdatas": [
        "n1.domain.com.","n2.domain.com.","n3.domain.com."
      ]
    }
  ]
}