Install Ruby
First you must install Ruby because Jekyll is a Ruby-based program and needs Ruby to run.
- Go to RubyInstaller for Windows.
- Under RubyInstallers, download and install one of the Ruby installers (usually one of the first two options).
- Double-click the downloaded file and proceed through the wizard to install it.
Install Ruby Development Kit
Some extensions Jekyll uses require you to natively build the code using the Ruby Development Kit.
- Go to RubyInstaller for Windows.
- Under the Development Kit section near the bottom, download one of the For use with Ruby 2.0 and above… options (either the 32-bit or 64-bit version).
- Move your downloaded file onto your C drive in a folder called something like RubyDevKit.
- Extract the compressed folder’s contents into the folder.
-
Browse to the RubyDevKit location on your C drive using your Command Line Prompt.
To see the contents of your current directory, type
dir
. To move into a directory, typecd foldername
, where “foldername” is the name of the folder you want to enter. To move up a directory, typecd ../
one or more times depending on how many levels you want to move up. To move into your user’s directory, type/users
. The/
at the beginning of the path automatically starts you at the root. - Type
ruby dk.rb init
- Type
ruby dk.rb install
If you get stuck, see the official instructions for installing Ruby Dev Kit.
Install the Jekyll gem
At this point you should have Ruby and Rubygem on your machine.
Now use gem
to install Jekyll:
gem install jekyll
You can now use Jekyll to create new Jekyll sites following the quick-start instructions on Jekyllrb.com.
Installing dependencies through Bundler
Some Jekyll themes will require certain Ruby gem dependencies. These dependencies are stored in something called a Gemfile, which is packaged with the Jekyll theme. You can install these dependencies through Bundler. (Although you don’t need to install Bundler for this Documentation theme, it’s a good idea to do so.)
Bundler is a package manager for RubyGems. You can use it to get all the gems (or Ruby plugins) that you need for your Jekyll project.
You install Bundler by using the gem command with RubyGems:
Install Bundler
- Install Bundler:
gem install bundler
-
Initialize Bundler:
bundle init
This will create a new Gemfile.
-
Open the Gemfile in a text editor.
Typically you can open files from the Command Prompt by just typing the filename, but because Gemfile doesn’t have a file extension, no program will automatically open it. You may need to use your File Explorer and browse to the directory, and then open the Gemfile in a text editor such as Notepad.
-
Remove the existing contents. Then paste in the following:
source "https://rubygems.org" gem 'wdm' gem 'jekyll'
The wdm gem allows for the polling of the directory and rebuilding of the Jekyll site when you make changes. This gem is needed for Windows users, not Mac users.
- Save and close the file.
-
Type
bundle install
.Bundle retrieves all the needed gems and gem dependencies and downloads them to your computer. At this time, Bundle also takes a snapshot of all the gems used in your project and creates a Gemfile.lock file to store this information.
Git Clients for Windows
Although you can use the default command prompt with Windows, it’s recommended that you use Git Bash instead. The Git Bash client will allow you to run shell scripts and execute other Unix commands.
Serve the Jekyll Documentation theme
- Browse to the directory where you downloaded the Documentation theme for Jekyll.
- Type
jekyll serve
-
Go to the preview address in the browser. (Make sure you include the
/
at the end.)Unfortunately, the Command Prompt doesn’t allow you to easily copy and paste the URL, so you’ll have to type it manually.
Resolving Github Metadata errors
After making an edit, Jekyll auto-rebuilds the site. If you have the Gemfile in the theme with the github-pages gem, you may see the following error:
GitHub Metadata: No GitHub API authentication could be found. Some fields may be missing or have incorrect data.
If so, you will need to take some additional steps to resolve it. (Note that this error only appears if you have the github-pages gem in your gemfile.) The resolution involves adding a Github token and a cert file.
See this post on Knight Codes for instructions on how to fix the error. You basically generate a personal token on Github and set it as a system variable. You also download a certification file and set it as a system variable. This resolves the issue.