Replicate AWS Elasticsearch Domain
How to replicate an AWS Elasticsearch domain configuration?
Using AWS CLI
# Get domain config
aws es describe-elasticsearch-domain \
--domain-name my-domain \
--output json > domain-config.json
# Create new domain with same config
aws es create-elasticsearch-domain \
--domain-name my-domain-copy \
--elasticsearch-cluster-config file://domain-config.json
Important Considerations
- IAM policies - These need to be recreated separately
- Access policies - Export and import separately
- Encryption - Ensure KMS key permissions are set up
Backing up indices
# Create snapshot
curl -X PUT "https://es-endpoint/_snapshot/my-repo/snapshot-1"
# Restore
curl -X POST "https://es-endpoint/_snapshot/my-repo/snapshot-1/_restore"
Remember to test the replication in a non-production environment first.