Jekyll on macOS using MacPorts


Jekyll grows fast. Keeping it updated to the latest version is easy, if we keep every dependency to the latest version too, starting with ruby! The previous article on installing Jekyll on mac Sierra is too old to be used now. Also, it used the ruby version comes by default in macOS. That’s usually an older version. In order to get the latest version of ruby (or anything), there are paths available. I personally like macports. So, let’s get started.

macports

Make sure you have macports already installed. If you don’t have it yet, see the quick start guide on macports. Basically, you’d need xcode commandline tools (xcode-select --install) and then select the appropriate macports package to install depending on your macOS version. Once installed, verify it using the command… port version.

ruby

The current version of Ruby (as of this writing) is 2.4.x. It can be installed using the command… sudo port install ruby24. This will install ruby2.4 and gem2.4 binaries at /opt/local/bin. Let’s create symlinks to override the default ruby and gem (comes bundled with macOS).

sudo ln -s /opt/local/bin/ruby2.4 /opt/local/bin/ruby
sudo ln -s /opt/local/bin/gem2.4 /opt/local/bin/gem

bundler

Bundler is an easy way to pack gems for a Ruby project. You may install bundler using the command gem install bundler. You are likely to receive the error related to the permissions. Because, by default, gem tries to install globally. You may force gem to install its gems only to the local user by setting up the environment variable GEM_HOME to a local directory such as ~/.gem or ~/gem. I prefer the former.

jekyll

Finally, it’s time to install Jekyll.

gem install jekyll
cd ~/tmp
jekyll new my-awesome-site
jekyll serve

video

(coming soon) If you are a fan of learning through videos, here’s the video that covers most steps.