Setup Git Pages
This quick tutorial will describe the process for setting up GitHub Pages with a custom domain and HTTPS enabled.
Step 1. Uploading content
There are various methods to get GitHub Pages published. Using the gh-pages
branch keeps the master
branch
free from the clutter of build artifacts. This works really well for CI as demonstrated on part 2 of this journey.
First step was to create the gh-pages
branch and push it:
git checkout -b --orphan gh-pages
git push -u origin gh-pages
To verify github has detected the branch you may check under GitHub Pages at:
https://github.com/{USER}/{REPO}/settings
data:image/s3,"s3://crabby-images/9ea8d/9ea8d3e693a6fe605588c9b274e5b80192b3e1bf" alt=""
Step 2. Custom Domain
To setup a custom domain, you must first configure it at:
https://github.com/{USER}/{REPO}/settings
data:image/s3,"s3://crabby-images/a64d3/a64d3ac681e59030b3f3ba79ce87ca1e593b47bb" alt=""
Then go to your domain registrar and configure a CNAME
to your custom domain.
data:image/s3,"s3://crabby-images/30668/3066845d3f77fae70426b3c129901ebaa73bb969" alt=""
Verify that the CNAME
has taken effect. Depending on your DNS server and settings this could take a few
hours to propagate.
$ dig why.jromero.codes CNAME +nostats +nocomments +nocmd
; <<>> DiG 9.10.6 <<>> why.jromero.codes CNAME +nostats +nocomments +nocmd
;; global options: +cmd
;why.jromero.codes. IN CNAME
why.jromero.codes. 1800 IN CNAME jromero.github.io.
Last part is to verify that GitHub is serving your website by double-checking the headers.
Specifically the server:
header.
$ curl -I http://why.jromero.codes
HTTP/2 200
server: GitHub.com
...
Step 3. Enable HTTPS
To enable HTTPS GitHub must be able to issue a certificate for your domain via Let's Encrypt.
With the use of this online tool a set of CAA
records can be generated that enables
Let's Encrypt to issue certificates.
NOTICE: All the changes are made to the top-level domain and not the subdomain.
The configuration will end up something like this:
Name Type Value
jromero.codes. CAA 0 issue ";"
0 issuewild "letsencrypt.org"
0 iodef "mailto:root@jromero.codes"
Again, you'll go to the domain registrar and configure 3 CAA
records to your custom domain.
data:image/s3,"s3://crabby-images/b282b/b282b83e5e40986ffd887fb3b815ae621cf2409e" alt=""
After applying the changes and waiting for propagation, a quick dig
should show your changes:
$ dig jromero.codes CAA +nostats +nocomments +nocmd
; <<>> DiG 9.10.6 <<>> jromero.codes CAA +nostats +nocomments +nocmd
;; global options: +cmd
;jromero.codes. IN CAA
jromero.codes. 1799 IN CAA 0 iodef "mailto:root@jromero.codes"
jromero.codes. 1799 IN CAA 0 issue ";"
jromero.codes. 1799 IN CAA 0 issuewild "letsencrypt.org"
Additionally, you should see an update to the Enforce HTTPS
option:
data:image/s3,"s3://crabby-images/bd4dc/bd4dc93cbe43ed6a04aa7f051084def4d946ef0e" alt=""
Eventually, this will change to:
data:image/s3,"s3://crabby-images/aa31b/aa31b94f9e46c164648a01c220a3dac03b23d7fa" alt=""
You can verify by pulling up your website in chrome and checking the connection:
data:image/s3,"s3://crabby-images/55c63/55c63645b580948af528c5ae98669d9a67a9a4d2" alt=""
Done
You should now have a statically hosted site with no storage, traffic, or certificate cost!
data:image/s3,"s3://crabby-images/bd4b9/bd4b9eee345b2cce79b23b09c2a8e05c293a8af5" alt=""
Troubleshooting Tips
Now, if you ran into any snags, here are a few tips…
SSL Certificate
View connection handshake
curl -I -v https://why.jromero.codes
View certificate information
echo | openssl s_client -showcerts -servername why.jromero.codes -connect why.jromero.codes:443 2>/dev/null | openssl x509 -inform pem -noout -text