NAME
route53 - Manage your DNS entries on Amazon's Route53 service
DESCRIPTION
route53 will manage your Amazon Route 53 account
SYNOPSIS
route53 {key and id} [options] action [action arguments]
Either -keyfile
and -keyname
or -id
and -key
must be provided.
OPTIONS
- -keyfile
-
The file which contains the keys and ids for the Route53 service, in the format used by Amazon's "route53.pl" script:
%awsSecretAccessKeys = ( "my-aws-account" => { id => "ABCDEFG", key => "12345", }, );
Defaults to
~/.aws-secrets
when not given. - -keyname
-
The name of the key to be used; in the above
-keyfile
example, it could bemy-aws-account
. - -id
-
The AWS id to be used; in the above example it could be
ABCDEFG
. - -key
-
The AWS key to be used; in the above example it could be
12345
. - -wait
-
For the commands which support it, waits for the change requested to be in
INSYNC
status before returning. This is done by querying for the change status every 2 seconds until the change isINSYNC
. Defaults to 0, meaning the requests return immediately. - -help
-
Prints the help page and exits
- -man
-
Prints the manual page and exits
ARGUMENTS
route53 performs a number of actions, each of which may take a number of arguments:
- list
-
Lists the hosted zones currently associated with the account. Takes no arguments.
- nameservers
-
Lists the nameservers for all the hosted zones currently associated with the account. Takes a hosted zone name as an optional argument to just show the nameservers associated with that zone.
- zone
-
Performs actions on a specific DNS zone. If a zone name is given, rather than an action, it shows the nameservers associated with the zone.
Possible actions are:
- create
-
Needs
--comment
and--callerreference
. Creates a new zone. Supports the--wait
option. - delete
-
Deletes the zone. The zone needs to be empty (containing only NS and SOA entries) before Amazon's Route53 allows its deletion. Supports the
--wait
option.
- record
-
Performs actions on a specific DNS zone record. A DNS zone name must be given. If no action is provided, it lists all records for the zone.
Possible actions are:
- list
-
This is the default action if no action is specified. Lists all DNS records for the zone.
If a
--type
is given, it lists only the records of the given type. If a--name
is given, it lists only the records which have the given name. If a--ttl
is given, it lists only the records which have the given TTL. If a--value
is given, it lists only the records which have a value matching the given one. - delete
-
Deletes one DNS record for the zone given. Can only delete a record which is univocally identified by filtering the records list by
--name
,--type
,--ttl
and--value
. Dies listing the matching records if too many entries match. Supports the--wait
option. - create
-
Creates a DNS record for the zone given. Needs all the following options in order to create the record:
--name
,--type
,--ttl
and one or more--value
. Supports the--wait
option.
EXAMPLES
Specify your credentials
You need to specify your credentials with one of the following notations. All the examples below use the --keyname
notation, defaulting to using the ~/.aws-secrets
file.
# Uses ~/.aws-secrets as repository, key name is specified
$ route53 --keyname my-aws-keyname
# Uses the given key file and key name
$ route53 --keyfile ~/.aws --keyname my-aws-keyname
# Uses the given key and id
$ route53 --key ABCDE --id DEFG
List your zones
Lists the zones names, ids and comments:
$ route53 --keyname my-aws-account list
Hosted zone:
id: /hostedzone/ABCDEFG
name: example.com.
callerreference: FGHIJK
comment: Zone for example.com.
Hosted zone:
id: /hostedzone/FGHJKL
name: anotherexample.com.
callerreference: QWERTY
comment: Zone for anotherexample.com.
Get all nameservers (and details) for all zones
Displayes a verbose list of the zone details and the nameservers which are authoritative for the zone:
$ route53 --keyname my-aws-account nameservers
Hosted zone:
id: /hostedzone/ABCDEFG
name: example.com.
callerreference: FGHIJK
comment: Zone for example.com.
nameserver: ns-123.awsdns-123.com
nameserver: ns-123.awsdns-123.co.uk
nameserver: ns-123.awsdns-123.org
Hosted zone:
id: /hostedzone/FGHJKL
name: anotherexample.com.
callerreference: QWERTY
comment: Zone for anotherexample.com.
nameserver: ns-456.awsdns-456.com
nameserver: ns-456.awsdns-456.co.uk
nameserver: ns-456.awsdns-456.org
Get just the nameservers for a specific zone
Displays a terse list of the nameservers, one per line:
$ route53 --keyname my-aws-account nameservers example.com.
ns-123.awsdns-123.com
ns-123.awsdns-123.co.uk
ns-123.awsdns-123.org
This allows the nameservers to be used in scripting:
$ for nameserver in
$( route53 --keyname my-aws-account nameservers example.com. );
do
# do whatever you want with $nameserver
done;
Create a new zone
Creates a new zone:
$ route53 --keyname my-aws-account zone create example.com. \
--comment 'Zone for example.com.'
--callerreference 'unique id for this'
You can optionally specify --wait
to wait for the zone to have been effectively created. Otherwise the command returns as soon as the request has been sent to Route 53.
Delete a zone
Deletes a zone (assuming the zone contains only SOA
and NS
records):
$ route53 --keyname my-aws-account zone delete example.com.
You can optionally specify --wait
to wait for the zone to have been effectively deleted. Otherwise the command returns as soon as the request has been sent to Route 53.
List all DNS records for a zone
Lists all DNS records for a zone:
$ route53 --keyname my-aws-account record list example.com.
example.com. A 14400 127.0.0.1
example.com. MX 14400 127.0.0.1
example.com. NS 172800 ns-123.awsdns-123.com. ns-123.awsdns-123.co.uk. ns-123.awsdns-123.org.
example.com. SOA 900 ns-123.awsdns-123.com. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400
*.example.com. A 300 127.0.0.1
You can optionally specify --type
to display only DNS records of a given type:
$ route53 --keyname my-aws-account record list example.com. --type A
example.com. A 14400 127.0.0.1
*.example.com. A 300 127.0.0.1
Delete a specific DNS record for a zone
This example assumes we want to remove the *.example.com.
entry. One can check which parameters are needed to get the correct entry with the record list
first:
$ route53 --keyname my-aws-account record list example.com. --type A
example.com. A 14400 127.0.0.1
*.example.com. A 300 127.0.0.1
$ route53 --keyname my-aws-account record list example.com. --type A --ttl 300
*.example.com. A 300 127.0.0.1
Or can read the error message given in case there are too many matching records:
$ route53 --keyname my-aws-account record delete example.com. --type A
Too many records match:
example.com. A 14400 127.0.0.1
*.example.com. A 300 127.0.0.1
The lone record deletion:
$ route53 --keyname my-aws-account record delete example.com. --type A --ttl 300
Create a new DNS record for the zone
This adds a new record for the zone:
$ route53 --keyname my-aws-account record create example.com. \
--name test.example.com. --type A --ttl 300 \
--value 127.0.0.1
AUTHOR
Marco FONTANI <mfontani@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Marco FONTANI.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.