πŸ₯‡My First blog post: 'The best is yet to come!'

Hi! This is my first ever blog post. I'm hoping to have some more blog posts here soon. It's really hard to be a perfectionist with deadlines. But alas one must start somewhere.

Published on:

Updated:

Reading time: 6 minutes

too damn long

Building a blog is harddd.

In this post, I’ll share the tumultuous pain of creating my very own blog using Golang and Hugo. Believe it or not there’s not really any JavaScript on this site (UPDATE: I wanted to use some JS for the nav, so that’s what I did). But other than that it’s HTML, CSS, a sprinkle of SVG, and of course the tears of existential pain embedded into the fabric of every page.

Why Golang and Hugo?

Let’s start with the choice of tools – Golang and Hugo. The truth is, when I sat down to make this site, Golang’s efficiency and “blazingly fast” concurrency really attracted me. Back in 2018, static site generation was all of the rage. If you don’t know SSG’s allow you to create websites that are completely static, aka just a file. Web servers are SO good at this that it makes your site very quick because it’s literally just text on a page. The beauty is that a SSG will compile Markdown posts into valid HTML and package it up nicely, this makes blogging super easy.

The thing that stuck out the most was that Hugo could compile a large number of blog posts in like a couple milliseconds and the fastest JavaScript static site generator comparatively (Gatbsy) would take like a “couple years” to compile a blog post (or so that’s what I felt to be true if I were to try it out on my 2010 Macbook). My 20 year old pea-sized brain really wanted that SPEED, so naturally I chose Hugo. Joke was on me though because I only have one blog post as of Jan 2024. I also currently own an 2023 M2 Macbook Pro, and idk if you know but that means I can comfortably open up two instances of VSCODE at the same time. That’s right ladies my RAM and CPU usage goes dummy hard. I might as well be mining bitcoin… The other gotcha is I also want to switch to NextJS too. I want to switch to NextJS because: 1) “ooh shiny” and 2) to prove to every recruiter that hasn’t been replaced by AI yet that I can use React. I digress.

When building the site I soon discovered the Golang community is a bit smarter than me. It’s also much smaller than the JS community. This meant there wasn’t a large amount of secondary documentation. As of this update, it looks like Luke Smith has a video on how to use Hugo so if you’re a Linux Nerd you’ll be safe here our overlord has deemed this software bloat free; go use it.

1: Golang’s Syntax

Golang as a language

Let’s start from the top: Golang’s syntax. If you’re familiar with C, you’ll be “C-ing” yourself smile because it’s pretty similar. This is likely because Rob Pike had a hand in designing both. It’s truly got some of the power of C with the weird simplistic beauty of Python. Golang’s known for its simplicity, but that doesn’t mean it’s easy. If you’re used to JavaScript, it’ll be a bit more different. The syntax and features were a bit weird early on. However, once I got the hang of it, Golang became pretty straightforward. The templating language wasn’t so bad since I was familiar to using Django’s templating language, but the lack of feedback on errors have been annoying. I think it’s more of a Hugo thing than a Golang one.

Challenge 2: Hugo’s Static Nature and Template Maze

Customizing the look and feel of my blog was where the real adventure began. Like I said, the lack of feedback on errors from Hugo is what plagued 20-something year old G-mo. Luckily my evil ex-girlfriend who’s good at design, helped design my site to be as simple as possible. So crafting the perfect template and theme didn’t have the highest overhead. I didn’t need crazy animations, or custom dynamic page creation, I just needed a place to share my resume and prove I can code. The components that were needed were that of the tried and true HTML skeleton:

The only dynamic bit was going to be <Main/> and Hugo’s really good at templating in this basic way.

The key thing to know about Hugo it that it has two types of pages. Single pages, and List pages. The cool bit is they’re aptly named as such: single.html and list.html. When interfacing with it, you can even import a theme if you want, I have an example demo site using a theme on Github Pages here

Once I understood this structure of Hugo where things go like the layout of your site goes in layout/ and content goes in content/ things became much easier:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
.
β”œβ”€β”€ README.md
β”œβ”€β”€ archetypes/
β”‚Β Β  └── default.md -- Can interact with pre-defined pages here
β”œβ”€β”€ config.toml    -- Store Global Variables to reference here
β”œβ”€β”€ content/       -- Where your markdown content goes
β”‚Β Β  β”œβ”€β”€ about.md
β”‚Β Β  β”œβ”€β”€ blog/
β”œβ”€β”€ layouts/       -- Where the structure of your site goes
β”‚Β Β  β”œβ”€β”€ 404.html   -- You can make a 404 page too
β”‚Β Β  β”œβ”€β”€ _default/
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ baseof.html
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ list.html
β”‚Β Β  β”‚Β Β  └── single.html
β”‚Β Β  β”œβ”€β”€ about/
β”‚Β Β  β”‚Β Β  └── single.html
β”‚Β Β  β”œβ”€β”€ blog/
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ list.html
β”‚Β Β  β”‚Β Β  └── single.html
β”‚Β Β  β”œβ”€β”€ index.html
β”‚Β Β  β”œβ”€β”€ partials/   -- Where ur components go
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ footer.html
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ header.html
β”‚Β Β  β”‚Β Β  └── main.html
β”œβ”€β”€ netlify.toml    -- Config file netlify uses
β”œβ”€β”€ public/
β”œβ”€β”€ static/         -- Where I keep my CSS and junk
β”‚Β Β  β”œβ”€β”€ assets/
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ gmo-logo.svg
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ pines.svg
β”‚Β Β  β”œβ”€β”€ css/
β”‚Β Β  β”‚Β Β  └── style.css
β”‚Β Β  β”œβ”€β”€ img/
β”‚Β Β  β”‚Β Β  └── profile-pic.jpg
└── themes         -- Optional place to store a theme

Triumph 1: Speedy Development and Deployment Wins the Day

Once I got past these initial hurdles, and read the docs a bit, the magic started to happen. Hugo’s static site generation made it easy to create my desired site, and with Hugo running I could see changes instantly. It was as easy as using the Hugo server command.

The real beauty came in deployment to a CDN. Netlify makes it dummy easy with their free integration. In my opinion, all of the people working at Netlify deserve a big old smooch. I currently don’t think I pay anything too! Absolute bonkers.

This efficiency was a game-changer. Netlify has a great thing going. Even though I’ll likely switch to Vercel, I think both services are amazing and I’ve deployed documentation using Netlify a bunch.

Conclusion: Life is pain, but we gotta scrape the joy out of it every chance we get

Building my blog with Golang and Hugo was like riding a roller-coaster. There were stomach-dropping moments of confusion, but I’m happy I did it. Despite the challenges, the end result is a blog that’s uniquely mine.

Thanks for being here 🍍