Wordpress to Jekyll (with bonus Github Pages info)
After paying another too-high hosting bill, I heard a dear friend mention that he had moved his sites to AWS to minimize cost. I’ve hosted my site for ~12 years as a full-fledged Wordpress install, and while that has been ok, it definitely is overkill. I have used various methods to post, including blogging software that has gone EOL, and engines that convert markdown to wordpress. All of them left something to be desired. I have been writing nearly everything at work in markdown, from meeting notes, to release notes, to project plans, and it seems like MD is here to stay. Time to move, now that I have 11 months of hosting to do it! GitHub Pages is free, and I get to use markdown. Lets do it!
Presumptions:
- Windows with admin access
- Wordpress site that works
Wordpress to Jekyll
- Install Visual Studio Code from https://code.visualstudio.com/
- Install git from https://git-scm.com/download/win
- Log into your Wordpress site
- Install the “wordpress-to-jekyll-exporter” plugin from Github or the Wordpress plugin marketplace - https://github.com/benbalter/wordpress-to-jekyll-exporter
- Activate the plugin and click “Tools” and “Export to Jekyll”. A zip file will download. You should back this up.
- Install ruby on your machine with winget. Open a CMD prompt and type winget install RubyInstallerTeam.RubyWithDevKit.3.2
- Install Jekyll. In your CMD, type gem install bundler jekyll. If your terminal says that Gem isn’t recognized, open a new terminal. If it still doesn’t work, check that ruby actually installed.
- After all that installs, run gem updatejust to make sure we’re all up to date.
- Using your terminal, navigate to wherever you’d like to store your blog’s files. For me, I store all of my repos on another disk, in a folder called GitHub. If you intend to use Github Pages to host your new site, you must name it (username).github.io, so my path will be H:\GitHub\jessewolcott.github.io. So, I’d usecd H:\Githubto get there.
- Create a new site using your jekyll install. Run jekyll new jessewolcott.github.io. If the folder already exists, make sure to add--forcebut be mindful that this will overwrite whatever it needs to, in that folder.
- Once that completes, CD into your new folder, and run jekyll serve. This will generate the site for local viewing, and you can hit it from http://127.0.0.1:4000 in your browser.- Now that this thing is running, whenever something changes in that directory, the site will be rebuilt, and you need only refresh your browser to see the changes. Neat!
 
- Unzip your blog export from Step 5. You will see a folder called “posts”. Inside of there are all of your blog posts from wordpress. You can copy these over to the _posts directory. Your site will rebuild and you can refresh and view it locally. Cool, right?
- You might not have noticed if you glanced quickly, but your site is probably called “Your awesome title” and a few other places, its clear we’re still rocking the default newly generated site. Navigate over to your directory and find _config.yaml. Open that up in your favorite text editor. If you take a glance at your Wordpress export, it doesn’t give you much, aside from URL, title and description. Fill out your_config.yamlto your liking. You may need to terminate thejekyll servejob to reload the new config.
- All of your blog posts are on one page. This is not great. Lets fix it! Back in your terminal, type gem install jekyll-paginate.
- In your site’s directory, find “Gemfile”. Underneath gem "jekyll-feed", "~> 0.12", create a new line and putgem "jekyll-paginate"
- In your _config.yaml, above the build settings, enterpaginate: 5. This will paginate every 5 posts. You can change this to your liking.
- In your site’s directory, you should see index.markdown. Rename this file toindex.htmland add the code on this site AFTER the existing info (below the last line of the “front matter”, which is that section at the top): https://jekyllrb.com/docs/pagination/
- Ok, we are getting somewhere now. The site is paginated, but still shows all the rest of the posts below. If we take a look at your index in Step 17, you’ll see that we are leaning on layout: home. That means that we are pulling layouts from the theme. If you are using the minima theme that is installed by default with Jekyll, as I was, you’ll need to update this layout. Thankfully, its easy! Head over to the theme’s folder, which is installed inC:\Ruby32-x64\lib\ruby\gems\3.2.0\gems\minima-2.5.1\_layoutson my computer. Open uphome.htmlin your text editor and comment out the part that displays the posts.
- Rebuild your site , and see that we have successfully paginated.
- Now, you can build your site using jekyll build, and copy_sitesto your web host (don’t forget your WordPress media!) and you’re good to go. If you’re using GitHub Pages, check out the section at the bottom.
Jekyll to GitHub Pages
So, we have our page built. It works great on a standalone server (which may be perfect if you are swapping out a Wordpress install). You still have to build your site and upload it each time you change it, and that may not be what you’re looking for. Thankfully, part of the reason Jekyll exists is to publish pages to GitHub Pages (and you don’t even have to build it). You basically get it set up, and then just push an .MD file, and it does its thing.
- Log into GitHub.com and create a repo called (username).github.io. My repo is jessewolcott.github.io. Make sure its publically viewable.
- Clone it to your local machine.
- Copy your Jekyll site to the git folder you just created, and clone it back up.
- You will notice that any modifications (including altering the theme) didn’t take. We have to change some things to make that go. Open up your _config.yamland commentgem "minima", "~> 2.5"by putting a # on the line. Then uncommentgem "github-pages", group: :jekyll_plugins.
- In your terminal, run gem install github-pages. Then runbundle update github-pagesto make sure its up to date.
- Once thats all sorted, copy the theme’s layout folder to your site’s directory (C:\Ruby32-x64\lib\ruby\gems\3.2.0\gems\minima-2.5.1\_layouts)
- Commit and push and you’re done!