Julia Evans

How to set up a blog in 5 minutes

Some people at Hacker School were asking for advice / directions for how to set up a blog. So here are some directions for a simple possible way!

There are lots of ways to set up a blog. This way will let you write posts with Markdown, version them with Git, publish them with git push origin gh-pages, and, most importantly, think for exactly 0 seconds about what your site should look like. You’ll need a working Ruby environment which is the hardest part. I use rbenv to manage my Ruby. I have spent months being confused about how to make Ruby work, so If you also need to set up Ruby it will take more than 5 minutes and this will be a total lie.

But! If you do, there is no excuse for you to not have a blog within 5 minutes (or at least not more than an hour). It took me 40 minutes but that was because I was also writing this blog post.

I used to worry a lot about what my website looked like, and then I realized if I wrote interesting blog posts basically nobody cared! All of my internal monologues about whether I should make it orange or not were for nothing. (the answer to orange is always yes, though). Lots of people subscribe with RSS anyway and never look at this site in the first place :) (I eventually commissioned my awesome friend Lea to redesign this site and now I think it looks awesome).

So if you have something to say, even if it is only one blog post’s worth of things, you can totally set up a site! Let’s start.

We’ll be using

  • Jekyll, a static site generator
  • Octopress to create a skeleton site without having to think about what it should look like
  • GitHub pages to host our site

Step 1: Install Octopress:

$ gem install octopress --pre
$ rbenv rehash

Step 2: Create a GitHub repo

You’ll need a place to put your blog! I made a new repository at https://github.com/jvns/fake-website. If you want your blog to appear at your-username.github.io, call this repo your-username.github.io. GitHub has some more instructions here and here.

If you want your blog to be on a custom non-GitHub domain that you own, there are directions about how to set up a custom domain.

Step 3: Create a skeleton site

Now we can make a website!

octopress new fake-website
cd fake-website
jekyll serve

This will create a new skeleton of an Octopress blog, and serve it to you on http://localhost:4000, where you can tinker to your heart’s content. Not too much! Remember, you only have 5 minutes.

Step 4: Push your website to GitHub

Now that we’ve maybe tinkered a bit, we’re ready for the world to see our (empty) website! If you put a Jekyll site in the gh-pages branch of a GitHub repository, GitHub will build it and serve it for you.

From inside fake-website, I did:

git init
git add .
git commit -m"My awesome blog"
git remote add origin git@github.com:jvns/fake-website
git checkout -b gh-pages
git push -u origin gh-pages

Step 5: Edit _config.yml

When I do this, I have a website magically generated at http://jvns.github.io/fake-website. But it looks totally broken! You need to make one more change: edit _config.yml to change the base URL of your website. Here’s my commit to fix it. 20

Step 6: Go blog (takes more than 5 minutes oops)

At this point you have probably discovered that if anyone on the internet tells you something takes 5 minutes they are definitely lying. But maybe you have succeeded anyway.

You can create new blog posts with octopress new post "My Awesome Post". I’m excited to see what you write!

How does SQLite work? Part 2: btrees! (or: disk seeks are slow don't do them!) Working remote, 8 months in (seeing humans is important!)