custom domain for github pages
There are far more problems in the world than setting up a custom domain. it’s ridiculous how a simple thing is made so complicated that any new user would break their head trying to make it work.
in this blog, i will share how to set up a custom domain using github pages.
data:image/s3,"s3://crabby-images/54051/5405114894c8f2db0894a959b96b9a9751a95e5f" alt=""
i already had github pages1 set up, and i bought a domain from hostinger. if you haven’t purchased a domain, you can get it here, and if you are lazy to create a static page on your own, you can use one of these templates.
Step 1
Deploying your page to github.
- if you need help, you can refer the docs. it’s pretty straight-forward.
Step 2
Sign in to your domain.
- Go to your domain’s home page. for hostinger domains go to: hpanel
- Under domains, choose the domain you want to set the custom domain to by clicking on “Manage”
- On the left panel, click on “DNS/Nameservers” to configure the CNAME and A records.
Step 3
Now this is the tricky part where most of the misconfiguration happens.
- If you find any existing “CNAME” records or “A records”, delete them
Step 4
Adding CNAME and A records
-
CNAME – There must be 2 CNAME records, and both records must point to ‘your-github-username.github.io’
- First CNAME record must have ‘www’
- Second CNAME record must be left blank
After saving both CNAME records, the result should look like this.
data:image/s3,"s3://crabby-images/28cf1/28cf11e6648d35abf49254143ca206235c9db441" alt=""
- A Records – There are 4 github IPs we need to add to our A records, and they are as follows:
185.199.109.153
185.199.110.153
185.199.111.153
After saving all the A records, the result should look like this.
data:image/s3,"s3://crabby-images/d9c0e/d9c0edb43240e3aba8020afd4def8beb16e9de27" alt=""
Step 5
Add the custom domain to your github.io page.
- Head to your GitHub repository and click on the Settings tab.
- Then, click on the Pages tab and enter your custom domain in the Custom Domain field –> Hit Save
- Wait for 15 mins for the TLS cert to be generated.
And just like that, you have set up your custom domain to GitHub Pages!