Post

Deploy Jekyll Website to Github and Godaddy (Custom domain)

Deploy Jekyll Website to Github and Godaddy (Custom domain)

After I wrote my first blog post, I decided to go for pushing it to Github. It took some time to figure out how to do it. So, I decided to document it here.

Understand Theme

Most of the tutorials available online about deploying the Jekyll site to GitHub says that you simply push your files to your remote repo and GitHub would automatically build your site. But that is not true for all the themes. Each theme has its workflow as decided by its developers. They are generally documented in their wiki or documentation site. The Jekyll theme I use Chirpy is very well documented and instructions are clear on how to deploy. Therefore, spend some to reading and understanding the workflow mentioned in int documentation https://chirpy.cotes.page.

Publishing the local Jekyll site to the remote repo and publishing the same in https://wxguy.github.io involves modification to be done at the local and remote repo. Let’s discuss them one by one.

Push Changes to GitHub

This Chirpy theme uses GitHub Actions to generate your site on a remote server. You need to have enough permission to do it in the remote repo. Go to GitHub/username/username.io/settings –> Actions –> General –> Scroll down the page to select “Workflow Permissions” and “Read and write permissions”.

There is a shell script deploy.sh under the tools directory that will run on the remote server. After writing your article, you can push local files to remote through git. Firstly, go to the root of your local repo and do the following to initialise your repo and add all files.

1
2
git init
git add .

You can check the status using the git status command. Though you can use git commit -m 'Fresh deployment' for staging your commit and git push -u origin master for pushing it to the remote repo, I could not succeed as it did not allow me to do so due to authentication failure. Therefore, I used https://www.gitkraken.com/ Git GUI for pushing the files. I found it convenient and easy to use. It automatically used my ssh key to push the commit which also solved my authentication issue.

Changes at GitHub repo

Once the commit is made to GitHub, it will trigger the GitHub Actions workflow. This would run the tools/deploy.sh file on the remote server to generate the site. In my case, the workflow did not completed successfully. Then I went to the remote repo on GitHub and status of run under the Actions tab. I had to rerun the process to complete it successfully. This will create another branch gh-pages in the remote repo. The last step to be forwarded is to set the branch and directory for publishing your site. Go to GitHub repo –> settings – > Pages –> Select gh-pages as a branch and /root as a directory. Ensure to save the changes. That’s it. Wait for a few min. The site username.github.io would be up and running after a few min.

It is highly recommended that you clear your cache and cookies before testing your site under https://username.github.io.

Enable Custom Domain (Optional)

This step is an optional one. If you wish to have your domain display your bog, then it is possible to do by following a few more additional steps. Remember that it cost you money. The first step is to buy a domain. There are many sites where you can buy your custom domain. I have chosen https://www.godaddy.com for the sole reason that it was cheap. You can use any other domain sale related site to purchase a domain name of your interest.

I bought http://wxguy.in. I had to modify at two locations to make the site live. Firstly, log in to https://www.godaddy.com and select Manage Domain which you will find under the newly purchased domain id. Then click Domain Settings and then click Manage DNS. Your domain settings will look like the below.

TypeNameDataTLL
A@custom600 seconds
NS@ns51.domaincontrol.com.1 Hour
NS@ns52.domaincontrol.com.1 Hour
CNAMEwwwyour-domain-name.1 Hour
CNAME_domainconnect_domainconnect.gd.domaincontrol.com.1 Hour
SOA@Primary nameserver: ns51.domaincontrol.com.1 Hour

We need to insert four DNS addresses 185.199.108.153, 185.199.109.153, 185.199.110.153, and 185.199.111.153 to point to GitHub. We can edit the first row (Type A) to insert 185.199.108.153. Then add three more additional Type A rows to insert the remaining three IP addresses 185.199.109.153, 185.199.110.153, and 185.199.111.153.

Then edit the CNAME row where your-domain-name. is indicated to insert your GitHub pages site name (username.github.io). Do not edit any other fields. The final table would now look like this.

TypeNameDataTLL
A@185.199.108.153600 seconds
A@185.199.109.153600 seconds
A@185.199.110.153600 seconds
A@185.199.111.153600 seconds
NS@ns51.domaincontrol.com.1 Hour
NS@ns52.domaincontrol.com.1 Hour
CNAMEwwwwxguy.github.io1 Hour
CNAME_domainconnect_domainconnect.gd.domaincontrol.com.1 Hour
SOA@Primary nameserver: ns51.domaincontrol.com.1 Hour

Now head over to your local repo and create a file called CNAME and write your domain name you have purchased in it ie. wxguy.in. Push the files to GitHub. Wait for a few min to take effect.

To check if all the options are loaded properly, you can go to https://who.is and enter your domain name www.wxguy.in in the search field. Once the site is listed click on DNC Records and it should show all the records you have entered on your domain like below.

Custom Domain DNS Records DNS Records for wxguy.in from whois.com

Alternatively, you can also check the status using the dig command.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
$ dig wxguy.in

; <<>> DiG 9.18.2 <<>> wxguy.in
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 16649
;; flags: qr rd ra; QUERY: 1, ANSWER: 4, AUTHORITY: 0, ADDITIONAL: 1

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 512
;; QUESTION SECTION:
;wxguy.in.                      IN      A

;; ANSWER SECTION:
wxguy.in.               600     IN      A       185.199.108.153
wxguy.in.               600     IN      A       185.199.111.153
wxguy.in.               600     IN      A       185.199.110.153
wxguy.in.               600     IN      A       185.199.109.153

;; Query time: 80 msec
;; SERVER: 192.168.1.1#53(192.168.1.1) (UDP)
;; WHEN: Mon May 02 23:09:15 IST 2022
;; MSG SIZE  rcvd: 101

Now onwards, you can access your site on your own domain wxguy.in directly instead of username.github.io. Even if you try to access username.github.io, it will redirect to wxguy.in.


You can download this article from here for free.


This post is licensed under CC BY 4.0 by the author.