Table of Contents
As one has to maintain multiple copies in order to have backups of data, having multiple copies without any proper metadata may lead to some disastrous situations. Previously, as we have learnt about “How To Create an S3 Bucket on AWS“, today we are going to learn about a solution (version control) for maintaining different versions of a particular type of data, further, we will be understanding about “version control on an S3 bucket”.
Step 1: Create a new S3 bucket
We are going to create an S3 bucket, as shown below we have created a bucket with a name “versioning-geekylane“.
data:image/s3,"s3://crabby-images/976dc/976dcbf3b7112cb52f0562a116f07ed979163a5e" alt="Create a new S3 bucket versioning geekylane"
Now, after creating this bucket, we have to make the “versioning-geekylane” bucket as “public“.
If you do not know how to make an S3 bucket public, then please follow -> Make an S3 Bucket Public and look for “Step 6“
data:image/s3,"s3://crabby-images/6bb44/6bb44b1fd7fc6a76db1bb20830561899e646eeae" alt="Bucket now have public access"
Step 2: Enable versioning or version control on S3 bucket
From the “Amazon S3” dashboard, click on the “S3 bucket” you want to enable versioning on, after that look for “Properties” tab and from there you will be seeing something like shown below.
data:image/s3,"s3://crabby-images/17c94/17c94d6c79784ba7ad331551f09a59e6183901ab" alt="Under properties of an S3 bucket click on versioning"
After that, click on the “Versioning” block and you will be asked as shown in the screenshot below.
Select “Enable versioning” as we did, and click on “Save” icon.
data:image/s3,"s3://crabby-images/3ae55/3ae55afb6e303cae12664806aa6e1de41d2c28ed" alt="Click on enable versioning for the S3 bucket"
You will be seeing that now the “Versioning” is enabled.
data:image/s3,"s3://crabby-images/3d3ec/3d3eca9b8c44b4af94585583bb8dd663f1efb6d6" alt="Versioning is now enabled for versioning geekylane S3 bucket"
Step 3: Upload a file to S3 bucket as “Version = 1”
In this step, we are going to create a file, here we are using “geekylane.txt” as our file holding the contents as shown below.
Note: This will be the “version 1” of this file.
data:image/s3,"s3://crabby-images/f0889/f0889317511616c6cd0d72f152f09779796cc522" alt="Upload a geekylane txt file to versioning geekylane S3 bucket"
The file has been successfully uploaded to the S3 bucket “versioning-geekylane“.
Note: The size of the file with “version 1” is 37.0 B
data:image/s3,"s3://crabby-images/85bb2/85bb223c45b624b518721008f5fc4b92390c2d15" alt="Note the size and date of this file"
Step 4: Access the file stored in S3 bucket
Note: As we have already made “versioning-geekylane” bucket public, we can directly access the contents resides under it without making any further changes to permissions.
Make sure, before accessing the file you enabled the public access to the file, otherwise, it will give you an “AccessDenied” error.
Simply copy the “Object URL” as shown below.
data:image/s3,"s3://crabby-images/0b00c/0b00c2291fcbc251577084789969ececd7ceac7e" alt="Copy the object URL of geekylane txt file"
After copying the “URL“, paste that in the “URL bar” in your browser and hit enter.
Note: The URL and file will be completely different in your case.
data:image/s3,"s3://crabby-images/31694/316940dc16078241d683d4b14f4edc07db2d5c0f" alt="Access the geekylane txt file using its object url from browser"
From above, we can see that the “geeklane.txt” file stored in “versioning-geekylane” is easily accessible.
Step 5: Update the file to “Version = 2” and upload it to S3 bucket
Now, we have changed the contents of the “geekylane.txt” with the following.
data:image/s3,"s3://crabby-images/b3661/b366182979c492afbaa740dd746ac7a22f3bc0a0" alt="The geekylane txt is updated to new contents"
Upload the updated “geekylane.txt” file to the “versioning-geekylane” bucket, as shown in the picture below.
Note: The size of the file with “version 2” is 71.0 B
data:image/s3,"s3://crabby-images/2dafa/2dafaa14c5f82e55d53634921913f4479e663404" alt="New and update geekylane txt file has been uploaded"
Again, copy the “Object URL” of this updated “version 2” of “geekylane.txt” file, as shown in the image below.
data:image/s3,"s3://crabby-images/019aa/019aa680dbab2822aee5b64d967a8f2d532937b0" alt="Copy the URL of the updated geekylane txt file"
Paste that “URL” in the browser’s “URL bar“.
Question: Wait! what? – Why is it giving us the “AccessDenied” error?
Answer: Because we have uploaded a new version of the “geekylane.txt” file, so in order to access it, we have to again make changes to its permissions and make it public.
data:image/s3,"s3://crabby-images/f42fb/f42fb915970de1785f2561ac34b5f6c29abf0436" alt="Unable to access the updated geekylane txt file showing access denied"
Making the file public.
data:image/s3,"s3://crabby-images/d94cf/d94cf6ced49fb2527b75ae11471b8d92ba91ae22" alt="Make the updated geekylane txt file public"
Accessing the updated “version 2” of the “geekylane.txt” file via a web browser.
From below, you can see that now we are able to access the updated “geekylane.txt” file.
data:image/s3,"s3://crabby-images/d34bc/d34bc2ecbcb1f4a447f1f6d24c672aaf77f91192" alt="Update geekylane txt file is now publicy accessible"
Step 6: View all the versions of a file stored in an S3 bucket
Click on the toggle button “Show” in the front of the “Versions” as shown below.
After that you will be able to see all the versions of a particular file.
data:image/s3,"s3://crabby-images/45469/45469175683b61fa7593915852191aa0f7ce381e" alt="Click on show button toggle to view all versions of an object in S3 bucket"
Click on “Hide” to only view the latest version of the file.
data:image/s3,"s3://crabby-images/6508b/6508b53b7c99e3de154a156b26676366c1611183" alt="Click on hide again to learn about deletion of an object"
Step 7: Deleting the files stored in an S3 bucket with versioning enabled
From the picture, you can see that we are deleting the “geekylane.txt” file.
Question: Will it be going to delete all the versions of the “geekylane.txt” files?
Answer: No, it will be only going to delete the “latest version” of the file, in this case only the “version 2” of “geekylane.txt” file is going to be deleted.
data:image/s3,"s3://crabby-images/818b5/818b5cc4224e7ab4a3c4a10582a6ed1e73e1c36a" alt="Delete an object in S3 bucket with versioning on"
After deleting the “latest version” of the file, you will be seeing something like shown below, if you do not have any other files already stored in your S3 bucket.
data:image/s3,"s3://crabby-images/4afe2/4afe27b3616f19b90a1bcfaf4558f2bf215929a0" alt="It will show the bucket is now empty but in reality it is not"
Click on the “Show” button to view the versions currently available.
Question: Why our “geekylane.txt” is not deleted?
Answer: By default, Amazon S3 will not delete the file, instead it will create a “Delete Marker” to the file.
Question: So, how do we actually delete a file stored in an S3 bucket enabled with versioning?
Answer: Simple solution is to first enable or go to the “show” all versions view so that you can see all the versions of a particular file and from there delete the version you want to be deleted.
From below, now we are in the “all version” view of a file, if we delete the “Delete Marker” as well as the “Latest Version” of the file, eventually we will be able to delete the “version 2” of our “geekylane.txt” file.
data:image/s3,"s3://crabby-images/a497e/a497ea0d8cbf9897f2453ec8418e41d80775e7b8" alt="This is the benefit of versioning"
Click on the “Delete” option under “Actions” tab in order to delete the “Delete Marker” of a file.
data:image/s3,"s3://crabby-images/8e751/8e75167addd74db7653cef1bfce91ee24f38221d" alt="Delete the delete marker of an object stored in S3 bucket with versioning enabled"
Confirm the deletion of “Delete Marker“.
data:image/s3,"s3://crabby-images/fcd00/fcd00c7afc687e1f9d5e217a580dad131292305e" alt="confirmation of deletion of delete marker"
After deleting the “Delete Marker“, we are again left with the “version 1” and “version 2” of the file.
data:image/s3,"s3://crabby-images/15acd/15acdea512220549fa1efb5e79cf41320f3bec51" alt="We still have our all the versions of geeklane txt file"
Click on the “Hide” icon to go back to the normal view.
data:image/s3,"s3://crabby-images/37325/373258858a23612647212a9fac2aa19489be3ed3" alt="The geekylane txt file is restored"
Comment here