Setting up a static website/blog with jekyll

June 24, 2019

3 minute read

A couple of people asked me for more info on my new blog setup here’s a rough outline of what’s involved in setup and posting. There are many ways of doing this, this is just the way that suited me best for now.

What you need to follow along:

Things I like about this setup

  • Built-in backups,
  • offline editing,
  • no shonkey web gui,
  • no charge for hosting with custom domain and https,
  • simple dev friendly templating,
  • a nice simple code-friendly mobile-friendly design,
  • full control.
  • public revision history of blog posts with no extra effort (no more “updated: blah” in blog posts)

Why jeykll fits that

A blog post like this one is just a text file in a special format called markdown. These can then be trivially source-controlled with git, which serves as version control and distributed backup in one neat package. I use git for work so although it’s not the easiest tool to use that’s not a problem for me. Theoretically if you don’t know git you could probably just do all your editing in the github web interface these days.

Here’s the entire folder structure of this blog as it stands right now. You can see there’s really not a lot too it.

$ tree
├── _config.yml
├── _drafts
│   └──
├── favicon.ico
├── fonts
│   ├── aramisi.ttf
│   ├── EBGaramond-Regular.ttf
│   └── FuturaPTLight.otf
├── images
│   ├── 404.jpg
│   ├── reverie-demo.png
│   ├── reverie.png
│   └── reverie-text.png
├── _includes
│   ├── analytics.html
│   ├── disqus.html
│   ├── meta.html
│   └── svg-icons.html
├── index.html
├── _layouts
│   ├── default.html
│   ├── page.html
│   └── post.html
├── _posts
│   └──
├── _sass
│   ├── _darcula.scss
│   ├── _highlights.scss
│   ├── _reset.scss
│   ├── _svg-icons.scss
│   └── _variables.scss
└── style.scss

7 directories, 30 files

The posts are just text files using the markdown format with a .md file extension instead of .txt and a short header for information like page title and tags. Here’s the top of this one:

layout: post
title: Setting up a static website/blog with jekyll
categories: [howto,backstage]

A couple of people asked me for more info on my new blog setup here's a rough
outline of what's involved in setup and posting. There are *many* ways of doing
this, this is just the way that suited me best for now.

How I set it up

I actually am reconfiguring from another setup, and used some advanced sillyness, but I’ll simplify that here down to roughly the steps you’d need to go from cold as I’m sure that’s more interesting to you.

  1. Buy a domain from GoDaddy
  2. Create a GitHub account
  3. Find a jekyll theme on become a base for your new site (the themes vary on how ready they are for you to just crack on). Here’s the reverie theme that I used with minimal customisation.
  4. Go into the settings for your repo, enabling github pages by choosing a
  5. turn on github pages, github settings
  6. configure your domain name, github settings
  7. enable https github settings
  8. Go to GoDaddy and set up the DNS to point to the github servers

Blogging with Jekyll

  1. Create new text file in the _posts folder, name it,
  2. steal the header block from above and customise it for your post,
  3. write stuff
  4. use markdown for layout,
  5. add images by saving them to an images folder and also adding them to your git repo, use ![alt text](/images/something.png) to show the image in your .md file,
  6. check everything in & git push to github,
  7. your changes are live within seconds of pushing.

If you aren’t up to the full git setup, you can edit your blog directly in github’s web interface.

  1. Creating a new post creating a post
  2. Editing a post editing a post
  3. Editing the text of a post editing the text of a post


Wordpress was overcomplicated for my needs, and slower to use/read, this new setup should mean I can tap away on the train and send new thoughts your way more regularly.


Share as Tweet || Share on LinkedIn
Post source code on GitHub - suggestions & PRs welcome!
Subscribe for updates on software development, contracting, side projects, blog posts and who knows what else. Read the archives for an idea of content.

Mailing list powered by the excellent