web-dev-qa-db-ja.com

AWS Route 53でホストゾーンをエクスポートするにはどうすればよいですか?

ドメインの設定のバックアップをエクスポートするオプションが表示されません。

たぶん私はDigでパブリックDNSの結果を保存する必要がありますが、友人がより良い方法を知っているかどうか疑問に思います。

19
gpupo

はい、それはよりフレンドリーな方法にすることができます。 cli53ツールの使用をお勧めします https://github.com/barnybug/cli5

セットアップしたら、試してみてください

cli53 export --full sciworth.com

そして、エクスポートゾーンをバインド形式で取得します。

27
astlock

追加のソフトウェアをインストールする必要はありません。あなたはawscliだけが必要です。

これが私が書いたものです。シンプルで魅力のように動作します。

#!/bin/bash -e
#
#  Author: Peycho Dimitrov
#
#  DESCRIPTION
#
#  Create full backup of all hosted Route53 zones / domains in your account.
#
#  REQUIREMENTS
#
#  Available s3 bucket (where your json files will be saved)
#  awscli (with cofigured credentials or IAM role)
#  gzip
#  awk
#
####################################

#  CONFIGURATION

region="us-east-1" # Your aws region
b_route53_tmp="/tmp/r53_backup" # Your temp directory
b_route53_bucket="s3://my-backups/route53" # Your backup folder in s3.

# END OF CONFIGURATION

# Do not edit here if you don't know what your're doing! #

mkdir -p $b_route53_tmp
echo "$(date) Backup all Route53 zones and resource records."
p_aws="$(which aws) --region $region"
r53_zones=$($p_aws route53 list-hosted-zones --query '[HostedZones[*].[Id, Name]]' --output text | awk -F'/' '{print $3}')
if [ ! -z "$r53_zones" ]; then
        while read route; do
                zone=$(echo "$route" | awk '{print $1}')
                domain=$(echo "$route" | awk '{print $2}')
                echo "Processing $zone / $domain"
                $p_aws route53 list-resource-record-sets --hosted-zone-id "$zone" --output json > "$b_route53_tmp"/$(date +%Y%m%d%H%M%S)-"$zone"-"$domain"backup.json
        done <<<"$r53_zones"

        echo "Archive json files."
        gzip "$b_route53_tmp"/*backup.json
        echo "Backup $zone / $domain data to $b_route53_bucket/$(date +%Y)/$(date +%m)/$(date +%d)/"
        $p_aws s3 cp "$b_route53_tmp"/ $b_route53_bucket/$(date +%Y)/$(date +%m)/$(date +%d)/ --exclude "*" --include "*.gz" --recursive
fi

echo "$(date) Done!"
7
Peycho Dimitrov

バインド形式にエクスポートする場合は、次のスクリプトを使用できます。

#!/bin/bash

zonename=$1
hostedzoneid=$(aws route53 list-hosted-zones | jq -r ".HostedZones[] | select(.Name == \"$zonename.\") | .Id" | cut -d'/' -f3)
aws route53 list-resource-record-sets --hosted-zone-id $hostedzoneid --output json | jq -jr '.ResourceRecordSets[] | "\(.Name) \t\(.TTL) \t\(.Type) \t\(.ResourceRecords[].Value)\n"'
2
SzTibu

簡単なバックアップスクリプトを書いた

#!/usr/bin/env bash

#set your vars
date=$(date +%j%m%Y)
backup_to="/change/this/to/your/destination/backup/dir"
backup_command_path="/usr/local/bin/cli53"
backup_command="cli53 export"

#check if cli53 exist
if ! [ -f $backup_command_path ]; then
    echo -e " file do not exist\n please install it from https://github.com/barnybug/cli53/releases/latest"
    exit 1
fi

#get list of domains to backup
domains=$(cli53 l | awk '{print $2}'| sed 's/.$//' | sed 's/Nam//')

cd $backup_to

for i in ${domains[@]}; do
    cli53 export $i > $i
done

#list backup directory
echo -e " the following zones where backup:\n"
ls -l
0
kabanus

AWS Route 53でホストゾーンをエクスポートするには、次の手順に従います(example.comホストゾーンを使用しているとしましょう)。

ステップ1:インストール– pip install route53-transfer

ステップ2:ゾーンをCSVファイルにバックアップします。

route53-transfer dump example.com backup.csv

ファイルの代わりにSTDOUTを使用する

route53-transfer dump example.com –

手順3:ゾーンを復元します。

route53-transfer load example.com backup.csv

使用する -代わりにSTDINからロードします

アカウント間で移行:

コマンドラインスイッチを使用して、アクセスキーと秘密キーを上書きします。

route53-transfer --access-key-id=ACCOUNT1 --secret-key=SECRET dump example.com
route53-transfer --access-key-id=ACCOUNT2 --secret-key=SECRET load example.com

プライベートゾーンを使用している場合は、–privateプライベートドメインを区別するには:

route53-transfer --private dump example.com example-private.csv
route53-transfer dump example.com example-public.csv
0
Dina Kaiser