Table of Contents
There are times when we just want more speed as well as redundancy of data stored in an S3 bucket. This is where the “cross region replication on S3 ” comes.
Question: What is actually “cross region replication“?
Answer: In short, it is nothing but creating multiple copies of data stored in an S3 bucket, which can be helpful in case of disaster recovery and high availability.
data:image/s3,"s3://crabby-images/59976/599763fa585d7eca6b5d5e9f0f959862b5de5335" alt="cross region replication on s3 bucket"
From the picture above, you can see that the bucket stored in “America = S3 bucket 2” is being replicated in the “Asia = S3 bucket 1” for high availability and redundant data.
Note: For enabling cross region replication on an S3 bucket, versioning must be enabled on the bucket.
Before going further, make sure you know -> How to create an S3 bucket
Also -> How to enable versioning on an S3 bucket
Step 1: Create an S3 bucket
In this, we have already created a bucket with the name “versioning-geekylane“, as shown in the picture below.
Moreover, you can notice that the “objects can be public” in this bucket.
data:image/s3,"s3://crabby-images/afab1/afab12fda0b3a934b743536867b21928d848b073" alt="Using the bucket created previously with versioning enabled"
Step 2: Add a cross region replication rule
For this, we have to go under the “Management” section of the “versioning-bucket” and after that, we have to go to “Replication” tab and from there select “+ Add rule” in order to add a cross region replication rule.
data:image/s3,"s3://crabby-images/8f0a2/8f0a2eb8d9a71520dd614b4163c37025c503ef25" alt="Add a cross region replication rule"
Step 3: Set Source Bucket
In this, we will be specifying which bucket we want to create a replication of, we are using “versioning-geekylane” as the source bucket, for reference check image below. After that click on the “Next” icon.
data:image/s3,"s3://crabby-images/d76eb/d76ebc1f937a6788e32f177ee85bc40d034baa0b" alt="Set a source for the replication rule"
Step 4: Set Destination Bucket
Now, in this step, we have to specify in which bucket we want to save/copy the contents/objects of “versioning-geekylane” bucket.
Simply click on the “Create new bucket“.
data:image/s3,"s3://crabby-images/cf495/cf495ed10991518f3b5cacd3a71bac02d2622eca" alt="For destination we are going to create a new bucket for cross region replication on S3"
We are going to create a new destination bucket, with a name “geekylane-crr” in the “Region = Asia Pacific (Mumbai)“, for reference check the screenshot below.
After that, click on “Next” icon.
data:image/s3,"s3://crabby-images/b647e/b647e5a77e937954045a103e01e29a486a363bd7" alt="A new bucket geekylane crr in Asia mumbai is created for destination"
Step 5: Set an IAM role
Here, we are going to create a new IAM rule for the cross region replication rule, the name of the “rule = geekylane-crr-rule” after that tick on the “Enabled” icon as shown below and click on “Next” icon.
data:image/s3,"s3://crabby-images/638d4/638d4dcf248dc33dbc88f3b5a16746b0e027d7aa" alt="Create a new IAM role name as geekylane crr rule"
Step 6: Review the cross region replication rule
Before saving the changes being made to the rule, review them and then click on the “Save” icon.
data:image/s3,"s3://crabby-images/be81a/be81acfc8b36029877a7139c204dc1cf451feb14" alt="Review the replication rule"
Step 7: Cross region replication is created
From the screenshot below, we can confirm that our crr rule has been created successfully.
data:image/s3,"s3://crabby-images/23684/236848a94d6d1340100138e4c805845b067fad6f" alt="Cross Region Replication updated successfully"
Step 8: Both the buckets are available – s3 cross region replication in multiple regions
From the image below, you can see that:
- Source Bucket = versioning-geekylane (US East (N. Virginia)
- Destination Bucket = Asia Pacific (Mumbai)
Both the buckets are situated in different regions.
data:image/s3,"s3://crabby-images/06778/06778efead2fabe02e9c75fb6d81c135d7141160" alt="Both the buckets are in different regions"
Step 9: Check the Destination Bucket
Question: Wait! what? Why is the destination bucket empty?
Answer: It is because the cross region replication rule is only going to apply on the newly created files and not for already present files.
data:image/s3,"s3://crabby-images/0c4b3/0c4b37afa65df051a03fb1ffdf10e4c73117edda" alt="The new geekylane crr bucket is empty"
Step 10: We are going to create a file
Note: We are using the file which we have used in the -> How to enable versioning on an S3 bucket
And this is going to be the “version 3” of the “geekylane.txt“, and have the following contents.
data:image/s3,"s3://crabby-images/59fb0/59fb03864ac50ab5e2c47fa05025e959b43f0a3c" alt="Updated version 3 of geekylane txt file"
Step 11: Upload a file to Source bucket
In this, we are going to upload a file, which we have created in the “Step 10“, for reference check the image below.
After uploading the file, you will see a “100% Successful” message at the bottom of your S3 dashboard.
data:image/s3,"s3://crabby-images/b0bb2/b0bb22adf58d793d0487feadb1543005902b608f" alt="Upload the new version to versioning geekylane"
Step 12: Check the Destination bucket
From below, we can see that the “geekylane.txt” file has bee replicated (copied) from the “versioning-geekylane” bucket to -> “geekylane-crr” bucket.
data:image/s3,"s3://crabby-images/25800/258000312599e2a97e5c5b2a7e0c1956b828dee6" alt="The geekylane txt is replicated to the the new bucket"
Step 13: Try to access the file
We are still getting an ERROR on accessing the “geekylane.txt” using the Object URL from Browser.
Question: Why is that? What is happening?
Answer: Only the contents are being copied from “Source to -> Destination” bucket, and not the “Bucket Policies” and “Access Control List“.
data:image/s3,"s3://crabby-images/ad733/ad7338cecbc5617c30be93025231de846cc4b6fa" alt="File is not accessible"
Step 14: Make the file/object in the destination bucket public
In this, we are going to give the public access to the file “geekylane.txt” which is being copied from the source bucket.
To do so, follow the image below.
data:image/s3,"s3://crabby-images/72694/72694441d89b3f69efbb2a4a846c50d739f92979" alt="Make the file public"
Step 15: Access the file Again
Now, the file “geekylane.txt” can be easily accessible from the “web browser” and do note that file is stored in the “destination bucket = geekylane-crr“.
data:image/s3,"s3://crabby-images/0ff14/0ff14e626c5a2e3d587b3e3456dec0f74144f400" alt="The file is now accessible"
Question: Does deleting a file from the “Source bucket = versioning-geekylane” is going to delete the file from “Destination bucket = geekylane-crr“?
Answer: No, by default on the new file/object creations are going to be replication and not anything else and not even the deletion. The file is deleted from the “source” is not going be deleted from “destination“.
Step 16: Delete file from Source bucket
Delete the “geekylane.txt” file from the “source bucket = versioning-geekylane“.
data:image/s3,"s3://crabby-images/19849/19849c6c2dfc12ea8d323f4c663bbc95d5295fb1" alt="We delete the latest version of file from the source bucket"
From the picture below, we can confirm that the latest version of the “geekylane.txt” file is being deleted from the “Source bucket = versioning-bucket“.
data:image/s3,"s3://crabby-images/19e0f/19e0fcdc433095f38dbcf26453ac6b2a7e262aea" alt="Source bucket is now left with two versions"
Step 17: Check the Destination bucket
From the contents of the “Destination bucket = geekylane-crr“, we can confirm that the latest version of the “geekylane.txt” is still available in it.
data:image/s3,"s3://crabby-images/0207e/0207ea2d0d8653df97e98fde4c0736b7524b6dc3" alt="Destination bucket still have the latest version"
Step 18: Access “geekylane.txt” from both the buckets
From the image below, we can see that the “Destination bucket = geekylane-crr” is still showing the latest version (version 3) of the “geekylane.txt” but the “Source bucket = versioning-geekylane” is now showing the version 2 of the “geekylane.txt” file.
Which, as conclusion states that the deletion of objects stored in an S3 bucket is not going to be replication from the source bucket to the destination bucket if the cross region replication is enabled on s3 bucket.
data:image/s3,"s3://crabby-images/9edcf/9edcfa33c5baad989d5fd3baf29f3a88e5cf3d9c" alt="Both have different versions because delete is not replicated"
More on S3:
More on AWS:
- How to set up IAM on AWS account? (Complete Step by Step Guide)
- One click WordPress set up with docker and docker-compose (local, live, cloud) (without SSL)
- Set-up a Nginx web server on ubuntu 18.04 EC2 Instance AWS
Comment here