This sample project demonstrate the S3 bucket cross region and cross account replication. Three S3 buckets are created in two regions in Account-A and one bucket in third region in Account-B. All the three buckets are encrypted with KMS Customer Managed Keys. Once an object is uploaded to the bucket in the primary region, the same is replicated in the other two buckets with storage class as Standard IA (in second region is Account-A) and as Glacier Instant Retrieval (in third region in Account-B). The entire stack is created HashiCorp Terraform.
- You need to have two AWS Accounts to implement this.
- Create three Customer Managed KMS Keys in the regions where you want to create the stack. First two in Account-A and the third one in Account-B
- Modify the KMS Key Policy to let the AWS Account (root) encrypt / decrypt using any resource using the created KMS Key. In the destination account KMS Key policy, grant permission to source account to use the key for S3 bucket.
- Create two profiles named Account-A and Account-B to execute AWS CLI Commands
- Clone the repository https://github.com/subhamay-cloudworks/0007-pisces-tf.
- First create the trust role to access Account-B from Account-B.
- change directory to tf_ac_role,modify the
terraform.tfvars
file with appropriate values and run the following terraform commands in sequence: -
terraform init
-
terraform validate
-
terraform plan
-
terraform apply -auto-approve
- change directory to tf_ac_role,modify the
- Create the stack consisting of three S3 buckets in three regions accross two account.
- Change the directory to repository root directory,modify the
terraform.tfvars
file with appropriate values and run the following terraform commands in sequence: -
terraform init
-
terraform validate
-
terraform plan
-
terraform apply -auto-approve
- Change the directory to repository root directory,modify the
-
Upload the sample sample file to the S3 bucket in Region-1 in Account-A
-
Within a few seconds (depending on the size) the object will be replicated to all the three regions.
-
To delete the stack run the command
terraform destroy -auto-approve
Post message in my blog (https://blog.subhamay.com)
Contributors names and contact info
Subhamay Bhattacharyya - [email protected]
- 0.1
- Initial Release
This project is licensed under Subhamay Bhattacharyya. All Rights Reserved.
Inspiration, code snippets, etc.