DEV Community

Trent Yang
Trent Yang

Posted on • Edited on

How to setup google domain for github pages

google domains and github pages

Intro

Github pages is easy to setup, but to attach a custom domain with google domains, you may run into problems. Here is how you can do it in 4 steps.

Prerequisites

STEP 1/4: Let gitHub pages know your custom domain

  • Go to your github repository settings page
    GitHub Settings

  • Add you custom domain name at Settings > GitHub Pages > Custom domain
    GitHub Settings Github Pages

STEP 2/4: Let your custom domain (trentyang.com) points to your github pages

  • Go to registar page on your google domains, select your domain
    Google Domain Register

  • Go to DNS > Custom resource records
    DNS Custom resource records

  • Add the record shown in the screenshot bellow. Note that you need to use the "+" button to add more urls.
    A record
    Here is the list of ips in the screenshot:

    • 185.199.111.153
    • 185.199.110.153
    • 185.199.109.153
    • 185.199.108.153

Incase these are outdated, you can also find the latest ones at github.

  • To confirm that your DNS record is set up correctly, use the dig command to do a lookup of your domain ```console

$ dig trentyang.com +noall +answer
trentyang.com. 3600 IN A 185.199.111.153
trentyang.com. 3600 IN A 185.199.110.153
trentyang.com. 3600 IN A 185.199.109.153
trentyang.com. 3600 IN A 185.199.108.153



  • Once the above is successful, your custom domain should work correctly. Go to your domain and take a look!

STEP 3/4: Let your www sub-domain (www.trentyang.com) point to your github pages

  • Add the following CNAME record
    CNAME record

  • You can use the following dig command to confirm that your setup is correct

    Enter fullscreen mode Exit fullscreen mode

$ dig www.trentyang.com +nostats +nocomments +nocmd
www.trentyang.com. IN A
www.trentyang.com. 1263 IN CNAME chun-yang.github.io.

Enter fullscreen mode Exit fullscreen mode




STEP 4/4: (optional but HIGHLY recommended) Enable HTTPS for your github pages

  • Go to your github repository settings page, under Settings > GitHub Pages > Custom domain remove your custom domain and save. GitHub Settings Github Pages
  • Then add it back and save again.
  • Now you should be able to check the "Enforce HTTPS" checkbox and secure your site!

If you enjoy reading it, here is my blog https://trentyang.com/how-to-setup-google-domain-for-github-pages/

Oldest comments (26)

Collapse
 
knpfletcher profile image
Karen Fletcher

This article is awesome, the most straightforward and thorough outline of the process! Thanks for posting!

Collapse
 
fuhrmann profile image
Ricardo Fuhrmann

Thanks, it worked!

Collapse
 
angoodkind profile image
Adam Goodkind

When I enter the dig command in Step 3, I only get the same 4 IP addresses from Step 2, and do not get a CNAME result. What have I configured incorrectly?

Collapse
 
enzotrompeneers profile image
Enzo Trompeneers

Same problem, any solution?

Collapse
 
angoodkind profile image
Adam Goodkind

Unfortunately I do not remember, but it did eventually work. I think you need to make sure there's only 1 entry on that page. In addition, things usually take 10-15 minutes to propagate through the system.

Collapse
 
marinadelkovamoro profile image
Marina Delkova-Moro

Hello,

I am stuck on step 2 and having trouble adding the IPs to my Custom resource records on Google domain. I get a notification "Record already in use" for the IPs that you have provided in this article and I can't figure out what are the updated ones. I have been reading through GitHUb documents for the last few hours and can't seem to find the current IPs.

Can you, please, provide the current IPs?

Thank you!!

Collapse
 
kellymtrinh profile image
Kelly

I got this error when I still had a subdomain forwarding on under Synthetic records. It went away after I deleted that!

Collapse
 
marinadelkovamoro profile image
Marina Delkova-Moro

Thanks, Kelly!! This makes sense now!

Collapse
 
dulani profile image
Dulani

Very helpful! I was mistakenly treating the "Registered Hosts" as the A record and the "Synthetic Domain" as the CNAME record. Your clear and concise post straightened me out!

Collapse
 
sayakpaul profile image
Sayak Paul

Hello. Thanks for the amazing tutorial. A couple of questions:

Here's the output of the dig:

$ dig www.sayak.dev +nostats +nocomments +nocmd

; <<>> DiG 9.10.6 <<>> www.sayak.dev +nostats +nocomments +nocmd
;; global options: +cmd
;www.sayak.dev.         IN  A
www.sayak.dev.      380 IN  CNAME   sayakpaul.github.io.
sayakpaul.github.io.    379 IN  A   185.199.108.153
sayakpaul.github.io.    379 IN  A   185.199.109.153
sayakpaul.github.io.    379 IN  A   185.199.110.153
sayakpaul.github.io.    379 IN  A   185.199.111.153
Enter fullscreen mode Exit fullscreen mode

When I navigate to sayak.dev, I get the following:

My Google Domain settings are correct as well I think:

Help appreciated :)

Collapse
 
alanjantz profile image
Alan Jantz

How did you resolve it? I'm getting the same error and I don't know what to do 😕

Collapse
 
nsylv profile image
Nikki Schmidt

Make sure you have www in Github for your custom domain

Collapse
 
asurakuo profile image
asura

You will need to get yourself a SSL certificate. SSL basically encrypts any thing that happens on your website so that no attackers and intercept the information

Very sorry for the 2 year late response.
please read support.google.com/domains/answer/...

Collapse
 
thecarpathiancoder profile image
TheCarpathianCoder

Thanks man!

Collapse
 
brpetrucci profile image
Bruno do Rosario Petrucci • Edited

Hi, thanks for the great tutorial! I'm getting an error, not sure where.

Everything seems to be working correctly - dig commands lead to the same output you show, the website shows up with a check in github "ready to be published at brpetrucci.com" etc, but when I try the URL it says the page cannot be found? I'm very confused

Collapse
 
fr3drick545 profile image
fr3drick545

I have the same issue. Have you been able to find a fix?

Some comments may only be visible to logged-in visitors. Sign in to view all comments.