Table of Contents
When it comes to mind about AWS, its S3 bucket service is one of the largest and durable platforms on earth. It stands for “Simple Storage Service (S3)“, and today we are going to learn about the same. We will be looking at how to “create an S3 bucket on AWS” step-by-step.
Step 1: Select the S3 service from aws dashboard
From the AWS dashboard, search for the “S3” under “Services” menu, and select it. For reference, look at the picture below.
data:image/s3,"s3://crabby-images/73dc4/73dc44abb58c233285930c2a2429c1f3563c5a10" alt="Select the S3 service form AWS dashboard"
Step 2: Create S3 bucket
After getting into the “S3 dashboard“, click on the “+ Create bucket” icon, as shown in the screenshot below.
data:image/s3,"s3://crabby-images/372f2/372f2f57de58c8ff068ace73326975baa5587fbb" alt="From AWS S3 console select Create Bucket Icon"
After clicking the button mentioned above, you will be seeing a screen like this on your dashboard.
On this screen, we have set the following details:
- Bucket name = “practice-geekylane”
- Region = US East (N. Virginia)
- Copy settings from an existing bucket = Leave Blank as of now
Note: The “bucket name” have to unique on your side because it is going to be a real DOMAIN NAME.
After filling up the details, click on “Next“.
data:image/s3,"s3://crabby-images/af706/af706e58c201d196c5e6c8b4ad20270ec0a70885" alt="Create a S3 bucket with a name practice-geekylane"
Now, you will be seeing a window like this, on this, do not change any options, leave it as they are already.
Question: Why we are not changing anything here?
Answer: Because we are going to change these later in this post.
data:image/s3,"s3://crabby-images/f56bc/f56bce278c02fa74502fe26239a30f2f9702b854" alt="On this window leave it as it is"
Now, you will see a “set permissions” screen,, leave it as it is.
data:image/s3,"s3://crabby-images/63fb8/63fb83690c1df5d0c04ab3e55fbabdc5ed9a6b34" alt="As of now leave all the permissions as they are by default"
Before proceeding further, you will see a “Review” screen as shown below. After cross-checking the details we have set so far for our “practice-geekylane” bucket, click on the “Create bucket” icon.
data:image/s3,"s3://crabby-images/b617b/b617bcc12a9a36907b1332217191eb21b1b7493f" alt="Review the S3 bucket and click on Create Bucket"
Step 3: Upload files to S3 bucket
Now that our “practice-geekylane” bucket is successfully created, we are now going to add some data to it.
Question: What is the meaning of “Adding data to the S3 bucket“?
Answer: It means that we are now going to upload some files (referred to as data) to our newly created “practice-geekylane“.
In order to add data to “practice-geekylane“, click on the bucket name as shown in the image below.
data:image/s3,"s3://crabby-images/ff829/ff829dd52646fc5ab8b35bc5c0d59aa014bf8e8e" alt="Our practice-geekylane bucket has been created"
After clicking there, a screen like shown below is going to be there on your side as well.
From this screen, click on the “Upload” button, and you will be prompted to your OS’s “File Manager” from there, navigate to the file which you want to upload to your S3 bucket.
data:image/s3,"s3://crabby-images/5adfa/5adfaf61492df4cd21f37976b31b2baf6b59e92d" alt="This the the bucket we just create and we can upload the files in here"
We have selected and uploaded a file named “GL logo.jpg“, from the picture below you can see.
After selecting the file from your system, click on the “Upload” button as shown in the screenshot.
data:image/s3,"s3://crabby-images/6e3f1/6e3f1c1a692e67b3c7e0498083bd909f37a0dc35" alt="Upload GL logo jpeg file to practice-geekylane bucket"
Confirmation, in your case also you will be seeing a “100% Successful” message like shown in the picture below.
data:image/s3,"s3://crabby-images/5c257/5c257b986cd337c558e6a9b7d8f819274df8972f" alt="File is successfully uploaded in the practice-geekylane S3 bucket"
Step 4: Access the file stored in an S3 bucket
Now, it is time to access our recently uploaded file “GL logo.jpg” to the “practice-bucket“.
In order to do that, click on the “checkbox” of the file name you uploaded, in our case, it is “checkbox” for “GL logo.jpg“. You will be seeing a “key = Object URL“.
data:image/s3,"s3://crabby-images/89091/8909156dabc047402a07091b79cd31e0d3600197" alt="Check the information of the file by clicking on it and go to the object URL"
After copying the “Object URL“, when we pasted it in the “URL bar” of the browser, you can see that we are getting an error message “Access Denied“.
data:image/s3,"s3://crabby-images/b0de7/b0de7ef1eca4892ed2c72699e4ba36035ff8c19e" alt="When we try to access the file it gives us the Access Denied error"
Question: Why accessing the “GL logo.jpg” file is give an “Access Denied” error?
Answer: Because we have not set any permissions on the “GL logo.jpg” file.
Step 5: Making public the file stored in an S3 bucket
In order to change the permissions of a file stored in an S3 bucket, do as shown below. Click on the “checkbox” of the image, after that click on “Actions“, from there you will be seeing a drop-down menu having an option as “Make public” click on that.
data:image/s3,"s3://crabby-images/46d18/46d189796b4288ff91955a34b0a5ffb3ecbc733d" alt="Make the S3 bucket public from S3 console"
Before making the file public, it is going to give you a message as shown in the image below, simply click on the “Make public” icon, to make it public.
data:image/s3,"s3://crabby-images/99f19/99f194d4e3811faca00abe77a04164c3e584c94c" alt="Confirmation message for making a S3 bucket public"
Wait! what? -> it is again giving an error, this time on making the file public, for reference check the picture below.
Question: Why is it giving the error?
Answer: It is because we have not set the permissions of the “practice-geekylane“, so in order to make any permissions change on the files stored in the “practice-geekylane“, we have to first change its permissions.
data:image/s3,"s3://crabby-images/b5d76/b5d76ff8550bc64c0bae47eb2407e9b4a7fe7ded" alt="Unable to make a S3 bucket public 100% Failed"
Step 6: Making the S3 bucket public
Traverse to your bucket, as we did in our case, now click on the “practice-geekylane” bucket and from there click on the “Edit public access settings” in order to make permissions work on files stored in it.
data:image/s3,"s3://crabby-images/84115/8411517fa152108c518f2ce5ab741aa9ec1bbf7a" alt="Edit public access setings of a S3 bucket"
Again, do note that we are leaving the “check-boxes” “untick“, as shown below, and click on the “Save” icon. This will result in making the “practice-geekylane” public.
data:image/s3,"s3://crabby-images/56c14/56c149adc47249df3087c2218b8da5119e3f5955" alt="ACLs and Bucket Policies are unchecked by default"
It will again be going to give you a confirmation message, type “confirm” and click on “Confirm” button.
data:image/s3,"s3://crabby-images/c716d/c716db496b0398218ebec921a643a3c50de7c0ed" alt="Confirm the public access change for a S3 bucket"
Step 7: Repeat “Step 5”
We are going to do the same as we did in “Step 5“.
data:image/s3,"s3://crabby-images/0d4a5/0d4a5a19b53c3cd4e9012f8203cb0da91c134c9a" alt="Again Make the GL logo jpeg file public"
Check the screenshot, it is now completed with a “100% Successful” message.
data:image/s3,"s3://crabby-images/39d2f/39d2fa3ddfba5bc861d6270e0c1def2233065e72" alt="Making the file is as public is now successful"
Now, again access the “URL” pasted in the “URL bar“, you will now able to access the file stored in S3 publicly. In our case, the file “GL logo.jpg” is now publicly accessible.
data:image/s3,"s3://crabby-images/df37b/df37bbf5e6857773bb152b2708f3956f7af333fd" alt="The GL logo jpeg can be seen via the object url"
Conclusion for “Create an S3 bucket on aws”
- You will be given a confirmation message every time you make changes to your S3 bucket permissions (ACLs or Bucket policies).
- By default, public access is denied for S3 bucket and its files.
More on AWS:
- Create an instance on AWS (complete guide)
- How to set up IAM on AWS account? (Complete Step by Step Guide)
- Install docker on AWS EC2 Ubuntu 18.04 (script method)
- Set-up a Nginx web server on ubuntu 18.04 EC2 Instance AWS
Comment here