How to fix: Domain does not resolve to the GitHub Pages server. Error in Github Pages for custom domain setup with Enforce HTTPS Enabled?

28,657

Solution 1

For anyone stumbling across this. Actually I realized I have outlined the correct method to set this up with Github Pages. And this is in line with what is recommended by Github as of today and works perfectly well. Just make sure you wait for the DNS Propagation to take effect which in some cases might take up to 24hrs. And this is what the problem was in my case.

Solution 2

Github shown me sucessive error message. After several iterations, github is happy with the following :

  1. In Settings > Pages :set up your github page :
    (you will have some error-warning message and Enforce HTTPS won't be ticked at first) enter image description here

  2. On my github repository's root, a CNAME file with the website name (with www):

www.example.com
  1. On my domain registration's DNS :
www                     28800  CNAME  MYUSERNAME.github.io.
@                       21460  A      185.199.111.153
@                       21460  A      185.199.109.153
@                       21460  A      185.199.110.153
@                       21460  A      185.199.108.153
  1. WAIT A DAY, ENJOY OUTDOOR WALK.

  2. The website is ok and in my terminal, a dig command returns :

$dig WWW.example.com +nostats +nocomments +nocmd
;WWW.example.com.   IN  A
WWW.example.com.    26728 IN CNAME  MYUSERNAME.github.io.
MYUSERNAME.github.io.   1527    IN  A   185.199.108.153
MYUSERNAME.github.io.   1527    IN  A   185.199.111.153
MYUSERNAME.github.io.   1527    IN  A   185.199.110.153
MYUSERNAME.github.io.   1527    IN  A   185.199.109.153
  1. Tick the "Enforce HTTPS".

Note: Replace example.com and MYUSERNAME by the values relevant to you.

Share:
28,657

Related videos on Youtube

Atif Ali
Author by

Atif Ali

A Paradoxical Optimist!

Updated on July 09, 2022

Comments

  • Atif Ali
    Atif Ali almost 2 years

    So I am trying to get a custom domain to work with my github pages user site. I have followed pretty much the standard procedure for doing this as follows: (recommended by github here too: https://help.github.com/articles/setting-up-an-apex-domain-and-www-subdomain/). Note I need both the apex domain (example.com) and the www subdomain (www.example.com) to resolve to my github pages user site at username.github.io (the website itself is a jekyll based blog and I have checked that it compiles successfully before I started this process)

    1. I added an A record to my DNS records at the registrar pointing to all of the four IP addresses provided by Github from the apex domain example.com:
      • 185.199.108.153
      • 185.199.109.153
      • 185.199.110.153
      • 185.199.111.153
    2. Next I went in and added a CNAME record for the www sub domain pointing to username.github.io
    3. And then I finally enabled the custom domain example.com under the settings tab of the repository (under Github Pages > Custom Domain), and also enabled the Enforce HTTPS option after it was enabled within about an hour.

    I have tried contacting my registrar and they said that everything in the DNS record seem fine and they get the following results:

    A records :

    example.com. 21460 IN A 185.199.111.153

    example.com. 21460 IN A 185.199.109.153

    example.com. 21460 IN A 185.199.110.153

    example.com. 21460 IN A 185.199.108.153

    CNAME :

    www.example.com. 7199 IN CNAME username.github.io.

    As expected.

    But I still get the following error in github (under the settings tab of the repository):

    "Domain does not resolve to the GitHub Pages server. For more information, see https://help.github.com/articles/setting-up-a-custom-domain-with-github-pages/."

    And when I try to access the site by typing either example.com or www.example.com, the browser redirects to https://example.com/ and I get the error (on Chrome):

    ERR_CONNECTION_REFUSED

    Note that there is a warning on the documentation by github saying:

    Warning: If your domain has HTTPS enforcement enabled, GitHub Pages' servers will not automatically route redirects. You must configure www subdomain and root domain redirects with your domain registrar.

    I have no idea how to get around this. I suspect this is the possible cause of the issue. So a solution might be to circumvent this redirection, I just do not know how I would do this.

    • David Jacquel
      David Jacquel over 5 years
      Just wait some time for DNS propagation and htpps://atifali.ca is working fine.
    • Atif Ali
      Atif Ali over 5 years
      yep just realized that was the only issue. Thanks though!
    • Atif Ali
      Atif Ali over 5 years
      @DavidJacquel I wonder how you actually got that domain address? Just curious since I tried making it as general as possible by removing any specific URLs.....was it a mere guess? Just curious haha
    • David Jacquel
      David Jacquel over 5 years
      I'm a well trained investigator. Wen someone asks a too general question, making debuging impossible, I search. And usually, I start my search on the profile page. In your case it was easy. ;-)
    • Atif Ali
      Atif Ali over 5 years
      Well @DavidJacquel I respect your level of commitment! We need more people like you in this world! Thanks mate :)
  • Adam_G
    Adam_G over 4 years
    Is there a way to know when the DNS settings have propagated?
  • Atif Ali
    Atif Ali over 4 years
    @Adam_G yes absolutely, you can check both the A and the CNAME records on websites like the following: whatsmydns.net, dnschecker.org, dnsmap.io and there are many more. Basically there is a timeout for these settings on servers I believe and in most cases its defaulted to 24hrs (I might be wrong though so be careful)
  • MoralCode
    MoralCode over 3 years
    the DNS propagation is - if i understand correctly - governed by the "time to live" or TTL value, which essentially determines the lifespan of how long that DNS entry should be cached before a new one is requested. This value can be seen in the entry from your question (example.com. 21460 IN A 185.199.111.153) the TTL value is 21460 seconds (almost 6 hours). Waiting 24 hours is still ideal, but this is also a decent estimate for how long it will take before the cached version of your DNS entry on github's servers expires and a new (and updated) one is fetched
  • diordna
    diordna over 2 years
    In my case the CNAME file I didn't have 'www' with the site. After I added It worked.