Creating This Blog

I never had the long-term plan of creating this website for myself. I remembered that I had an old repo using GitHub pages for a different project (TODO: Make that blog) that was no longer used. It was filled with old code from high school that was not a good representation of my best work. I wanted to delete it and put a placeholder in there. However, I felt a particular desire to find a good way of making a static website since I disliked working with raw HTML/CSS/JS. That is when I came across Hugo.

Hugo

A Reddit user once commented something along the lines of “Hugo is the front-end for back-end developers”. I am paraphrasing and couldn’t find the exact source, but I wholeheartedly agree! Hugo works by transforming markdown with other themes, templates, and content into HTML and CSS. This makes it easy to style, develop, and write without having to worry about tags, formatting, or unexpected errors. Written in Go, it is extremely fast and lightweight. Speed and size were not my main draws, but they were nice to haves for deployment.

Now, to be fair I did not look that deeply for different tools or solutions. I took a look at Hugo and said “Ah, yes. That one”. However, I don’t regret it at all. It is an extremely easy to use tool once you learn the general structure of how it works.

Theme Choices

Once I did the basic tutorial, I looked for a cool theme to use. After all, I wanted this to be an extension of my personality and general nerdiness. Risotto was exactly what I was looking for. It was stylish, minimal, and had a general nerdy vibe. It displayed relevant information and made it extremely easy to find what a user would be looking for. While other themes look more professional and offer more functionality, they weren’t me. I am not a fancy or flashy person. I prefer function over form almost any day of the week.

I was also able to chose a theme pretty easily as Risotto supports the base-16 format which made swapping themes extremely easy. I chose the horizon-dark theme and modified it to contrast a bit better. The result was this webpage you see now.

Deployment

I am using GitHub Pages to host this site. Previously, I stored everything in separate html files and wasn’t sure how to deploy this Hugo project. Everything by default was redirecting me to the README.md file in this repo. I found an action on the GitHub Marketplace to deploy everything automatically without having to think about what I was doing. Great!

I ran the action and it reported that it successfully deployed. Hooray!

Then when I checked on the site, it wasn’t there. Hmm.. odd. It said it deployed. What could be going on?

I did a bit more research and found another guide with a different file. It was similar in a lot of places but had a few different version numbers and thought maybe something went wrong that the logs didn’t show.

Drumroll please… And it deployed successfully and showed up!

Ok so I should be good to delete the old file right? WRONG. I deleted the old file and we were back to seeing the README.md file.

Upon closer inspection, I noticed that there were two actions that were running: a pages build and deployment from GitHub Pages and my own Hugo Build. As it turns out, inside of both of the build files were concurrency checks to make sure that anything in the pages group could only run one at a time without interrupting it. These concurrency checks made it so the pages build and deployment would finish first then the Hugo Builds would finish up. Since Hugo Builds took 10 seconds to finish, any deployment by it would be overwritten by the pages build and deployment task. The solution was to simply turn off GitHub Pages automatic deployment and simply run just the Hugo Builds action.

This was a very weird behavior at first, but in the end it makes complete sense when you have two services deploying to the same site.

Custom Domain

Originally, I had no intention of adding a custom domain. After all, they cost money and money is expensive. However, I found out that a perk of GitHub Education was a free domain name for a year from Name.com. Using existing systems on Name.com, it was easy to add the DNS A records for GitHub Pages and add the domain salata.software to this page!

I chose that domain name simply because I wanted something that had my name and conveyed what I did. I also learned that alliteration is a very powerful marketing tool so I chose to use my last name and .software to show that I work primarily in software development. I think it is neat overall!

Final Thoughts

Overall, I went into this side project not really knowing what I was doing or how anything works. In a way, I still don’t. However, I loved getting to learn this incredibly powerful tool! I am able to quickly write outlines of pages and everything else is handled for me. I do wish that it was a bit easier to edit themes, but I may just have to fork Risotto to make my own changes and customization. Either way, I am able to quickly and easily develop, build, and deploy new pages and manage the existing ones. When I say that I am passionate about learning new technologies, this is why.

Salata Software

A personal blog exploring the challenges and adventures of a Computer Science student


Read about how I built and deployed this site with Hugo and GitHub Pages

By John Salata, 2024-11-26


On this page: