We can host a website from S3 bucket in AWS. S3 is a highly scalable, extremely cheap and storage service. As it is a global service, so we do not bother to select any region. If we do not want to use any form, script or any type of input from users or we just want to provide information on our site, then, Static Web Hosting by using S3 bucket is really useful.
Generally, for a static website we need to have:
- Web Contents
- Web Location
- Public IP
- Domain Name Registration
- DNS Server
But if we go through AWS S3 bucket we need to perform:
- Register a Domain
- Create a Bucket
- Create a Bucket Policy (GetObject)
- Upload Files into the Newly Created Bucket
- Enable S3 Hosting
- Map IP to DNS via DNS Server
- Make a connection between Freenom and AWS
STEP 1: Register a Domain:
Visit a link https://www.freenom.com to register a free domain.
Find a free domain: Search a domain and purchase it as free
(in our practice we are using domain webshack.cf) âž” Continue âž” Checkout âž” Login via using Gmail or Facebook OR click on login if you have an account âž” Complete Order.
STEP 2: Create a Bucket:
AWS âž” Services âž” S3 âž” Create Bucket âž” Bucket name (it should be the same as the domain name): www.webshack.cf âž” Next âž” Uncheck all the boxes in 'Manage public access control lists (ACLs) for this bucket' to make bucket public âž” Next âž” Create Bucket.
Here, we can see that our bucket is created but access is not yet public (because of Implicit Deny).
STEP 3: Create a Bucket Policy:
AWS âž” Services âž” S3 âž” Select Bucket: www.webshack.cf âž” Permissions: copy Bucket ARN âž” Bucket Policy âž” Policy Generator âž” Policy Type: S3 Bucket Policy âž” Effect: Allow âž” Principal: * âž” Actions: GetObject âž” ARN: (paste copied Bucket ARN) âž” Add Statement âž” Generate Policy âž” Copy the code âž” Paste it in Bucket policy editor with a
'/*' (ARN/*) âž” Save.
If you want, you can use below mentioned Green colour code also:
Now the bucket has public access which AWS is notifying with orange indicator under Permissions.
If you want, you can use below mentioned Green colour code also:
{
"Id": "Policy1570222505991",
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1570222504297",
"Action": [
"s3:GetObject"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::bkt1adcvw/*",
"Principal": "*"
}
]
}
Now the bucket has public access which AWS is notifying with orange indicator under Permissions.
STEP 4: Upload Files into the newly created bucket
- Open notepad, put some contents in it and save it as 'index.html' again open another notepad window, put some contents in it and save it as error.html'.
- Go to the Bucket and upload files
in the bucket named www.webshack.cf:AWS âž” Services âž” S3 âž” Select the bucket 'www.webshack.cf' âž” Upload âž” Add files âž” Select files that you created âž” Upload.
STEP 5: Enable S3 hosting:
AWS âž” Services âž” S3 âž” Select the bucket
'www.webshack.cf' âž” Properties âž” Static Web Hosting âž” [*] Use this
bucket to host a website âž” Index document: index.html âž” Error document:
error.html âž” Save.
![]() |
Fig: Static Web Hosting |
If we want, we can verify our site is working or not by clicking:
…Permissions ➔ Static web hosting ➔ Endpoint: URL ➔ Copy this URL and paste it on the browser to check if we get the access.
For example, in the above figure, we can see the Endpoint URL.
STEP 6: Map IP to DNS via DNS server:
AWS ➔ Services ➔ Route 53 (it’s a paid feature of AWS but if we clear it within 12 hours, there is no charge) ➔ DNS Management: Get Started Now ➔ Create Hosted Zone ➔ Create Hosted Zone ➔ Domain name: webshack.cf (do not provide www) ➔ Comment (provide purpose): Testing s3 web hosting ➔ Type: Public Hosted Zone ➔ Create.
Create Record Set âž” Name: www (do not use dot after www) âž” Type: A-IPv4 address âž” Alias: Yes âž” Alias Target: Select the Bucket
(if we are not getting our bucket name, then maybe the bucket name is wrong OR
static web hosting is disabled) âž” Routing Policy: Simple âž” Create.
STEP 7: Make a connection between Freenom and AWS:
Login to freenom.com âž” Services âž” My Domains âž” Click on Manage Domain in front of our domain 'webshack.cf' âž” Management
Tools âž” Name Servers âž” [*] Use custom nameservers (enter below) âž” (Here,
paste all four nameservers from our AWS window one by one WITHOUT DOT) âž” Change
Nameservers.
![]() |
Fig: Nameservers |
Now, our website is hosted, we need to verify this by using our
domain (www.webshack.cf) on the browser.
Open Web Browser âž” Type www.webshack.cf âž” If there is
no access, then we need to wait for some time. In some cases may take a couple
of moments to be online.
=============================================================
CLEANUP:
As we know, route 53 service is a paid service, if we use it beyond 12 hours. To avoid charges we need to delete our created 'Record Set' & 'Hosted Zone' and 'Disable Web Hosting':
1) Delete Record Set:
AWS âž” Services âž” Route53 âž” Hosted Zones âž” Select the Site âž” Select the Record Set we want to delete âž” Delete Record Set âž” Confirm.
2) Remove Hosted Zone:
Go back to the Hosted Zones âž” Select the site âž” Delete Hosted Zone âž” Confirm.3) Disable Static Website Hosting:
AWS âž” Services âž” Select Bucket âž” Properties âž” Static Web Hosting âž” Disable Web Hosting âž” Save.
4) Now, if there is no need of the bucket, we can also delete the bucket:
AWS âž” Services âž” S3 âž” Select Bucket âž” Delete âž” Type the name of the bucket to confirm the deletion âž” Confirm.
Enjoy!
Thanks much Divakar for posting this article....Worked like crisp!!!
ReplyDeleteThanks for sharing this informative article on Static Web Hosting Services in detail. If you have any requirement to Hire OVH Hosting Services for your web hosting service. Please visit us.
ReplyDelete