How to fetch the AWS Route53 hosted zone id?

后端 未结 4 1343
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-13 11:46

I am newbie to Amazon Services and their API.

Using Amazon route53Clinet class, I know there is a method getHostedZone which get the Hosted Zone information on the

相关标签:
4条回答
  • 2021-01-13 12:21

    You can use listHostedZones or listHostedZonesByName to interrogate the service about your hosted zones.

    However... You really need to already know the hosted zone ID -- store or cache it -- because it's possible to create more than one hosted zone in Route 53 for exactly the same domain... and if your code blindly searched for the hosted zone by domain name, you could end up modifying the wrong one... particularly if you fall into the antipattern trap of assuming only one match is possible, and therefore you always select the first match.

    Simple deployments will only have one hosted zone for each domain name, but reasons you might have more than one would include private hosted zones (accessible only from inside your VPC) or duplicate public hosted zones, where you are doing a DNS rebuild or hard cutover. Route 53 allows you to create a second (or third, etc.) hosted zone with 4 different name servers.

    Also, of course, it makes sense to have this information locally to avoid making unnecessary API requests, which can cost time and money. The hosted zone id is, as you likely noticed, also visible in the console.

    0 讨论(0)
  • 2021-01-13 12:25

    I know this may be old but I was able to grab the ID with Powershell when initially creating the DNS zone by doing the following:

    $route53Script = aws route53 create-hosted-zone --delegation-set-id /delegationset/DELIGATIONID --name domain.com --caller-reference blablabla | ConvertFrom-Json
    $Route53ID = $route53Script.HostedZone.Id.replace("/hostedzone/","")
    

    This gives me the Zone ID that I can then use as a variable to do this:

    aws route53 change-resource-record-sets --hosted-zone-id $Route53ID --change-batch file://C:\default.json
    

    I don't know if it's the best way, but it works! I believe you can do almost the same thing in PHP. It's been awhile since I've written some bigger scripts in PHP though.

    0 讨论(0)
  • 2021-01-13 12:25

    This will give you a list with hosted zones ID's.

    aws route53 list-hosted-zones | jq '.HostedZones| .[] | .Id'

    0 讨论(0)
  • 2021-01-13 12:27

    I use the AWS CLI and pipe the JSON results to the jq tool:

    aws route53 list-hosted-zones-by-name | 
    jq --arg name "example.com." \
    -r '.HostedZones | .[] | select(.Name=="\($name)") | .Id'
    

    The jq expression selects each hosted zone JSON item that contains the name "example.com". Heads up that this may return more than one record.

    The output is the matching hosted zone id strings such as:

    /hostedzone/ABCDEF12345678
    

    You can then list resource record sets for a hosted zone id:

    aws route53 list-resource-record-sets \
    --hosted-zone-id "/hostedzone/ABCDEF12345678"
    
    0 讨论(0)
提交回复
热议问题