Simple backup and restore script for Amazon DynamoDB using boto to work similarly to mysqldump.
Suitable for DynamoDB usages of smaller data volume which do not warrant the usage of AWS Data Pipeline for backup/restores.
dynamodump supports local DynamoDB instances as well (tested with dynalite).
usage: dynamodump.py [-h] [-m MODE] [-r REGION] [-s SRCTABLE] [-d DESTTABLE]
[--readCapacity READCAPACITY]
[--writeCapacity WRITECAPACITY] [--host HOST]
[--port PORT] [--accessKey ACCESSKEY]
[--secretKey SECRETKEY] [--log LOG]
Simple DynamoDB backup/restore.
optional arguments:
-h, --help show this help message and exit
-m MODE, --mode MODE 'backup' or 'restore'
-r REGION, --region REGION
AWS region to use, e.g. 'us-west-1'. Use 'local' for
local DynamoDB testing.
-s SRCTABLE, --srcTable SRCTABLE
Source DynamoDB table name to backup or restore from,
use 'tablename*' for wildcard prefix selection
-d DESTTABLE, --destTable DESTTABLE
Destination DynamoDB table name to backup or restore
to, use 'tablename*' for wildcard prefix selection
(uses '-' separator) [optional, defaults to source]
--readCapacity READCAPACITY
Change the temp read capacity of the DynamoDB table to
backup from [optional]
--writeCapacity WRITECAPACITY
Change the temp write capacity of the DynamoDB table
to restore to [defaults to 100, optional]
--host HOST Host of local DynamoDB [required only for local]
--port PORT Port of local DynamoDB [required only for local]
--accessKey ACCESSKEY
Access key of local DynamoDB [required only for local]
--secretKey SECRETKEY
Secret key of local DynamoDB [required only for local]
--log LOG Logging level - DEBUG|INFO|WARNING|ERROR|CRITICAL
[optional]
The following examples assume your AWS access key and secret key is present in ~/.boto
Single table backup/restore:
python dynamodump.py -m backup -r us-west-1 -s testTable
python dynamodump.py -m restore -r us-west-1 -s testTable
Multiple (wildcard) table backup/restore:
python dynamodump.py -m backup -r us-west-1 -s production*
python dynamodump.py -m restore -r us-west-1 -s production*
The above, but between different environments (e.g. production-* tables to development-* tables):
python dynamodump.py -m backup -r us-west-1 -s production*
python dynamodump.py -m restore -r us-west-1 -s production* -d development*
The following assume your local DynamoDB is running on localhost:4567 and is accessible via 'a' as access/secret keys.
python dynamodump.py -m backup -r local -s testTable --host localhost --port 4567 --accessKey a --secretKey a
python dynamodump.py -m restore -r local -s testTable --host localhost --port 4567 --accessKey a --secretKey a
Multiple table backup/restore as stated in the AWS examples are also available for local.