Spoiler I’m so much into Docker that I could sing songs about how much it made my life easier. And you’re soon, too. Beware!
Just today I’ve got a request to review changes to introduce Jekyll as the documentation framework. I was earlier proposing it myself so I knew what the outcome of the review could be - APPROVED.
But…
I also knew that the guy who proposed the change was fighting the installation of Ruby gems and Jekyll to have a complete working environment for the documentation system on his own laptop. He was on Linux while I’m on Mac OS. He finally got it sorted out, but the final solution was not satisfactory to me - he installed additional dependencies onto his local machine directly and suggested the very same steps in README so others could follow his steps. I simply couldn’t approve it. Sorry.
The alternative was to use Docker and the docker-jekyll image. It makes Jekyll running in a self-contained container with no system-wide interaction with the local machine. And it’s officially supported and maintained by the Jekyll project itself.
Using Jekyll inside Docker
The steps to use Jekyll without installing Ruby, gems and other dependencies locally is to use the docker-jekyll image. It’s very safe because it’s a self-contained image and I’m not “infecting” my local working machine in any way (except installing Docker and pulling the image, but that’s acceptable).
Install Docker on your platform and do the following.
Go to the docs directory where your documentation lives and execute:
docker run --rm -v $(pwd):/srv/jekyll -t -p 4000:4000 jekyll/stable jekyll build
It will generate the docs from the sources and save the output into the current working directory (under _site).
Serve the docs using jekyll s which is the default command while spinning up a new docker-jekyll container.
docker run --rm -v $(pwd):/srv/jekyll -t --name=jekyll -p 4000:4000 jekyll/stable
Mind the name for the container - jekyll - so it’s easier to work with it later on.
➜  docs git:(39fd9c9) ✗ docker run --rm --volume=$(pwd):/srv/jekyll -t --name=jekyll -p 4000:4000 jekyll/stable
Configuration file: /srv/jekyll/_config.yml
            Source: /srv/jekyll
       Destination: /srv/jekyll/_site
      Generating...
                    done.
 Auto-regeneration: enabled for '/srv/jekyll'
Configuration file: /srv/jekyll/_config.yml
    Server address: http://0.0.0.0:4000/
  Server running... press ctrl-c to stop.
Open http://0.0.0.0:4000/ and have fun!
Stop the container using docker stop jekyll.
➜  docs git:(39fd9c9) ✗ docker ps
CONTAINER ID        IMAGE               COMMAND              CREATED             STATUS              PORTS                    NAMES
b6bb07d8b8aa        jekyll/stable       "/usr/bin/startup"   26 seconds ago      Up 26 seconds       0.0.0.0:4000->4000/tcp   jekyll
➜  docs git:(39fd9c9) ✗ docker stop jekyll
jekyll
➜  docs git:(39fd9c9) ✗ docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
➜  docs git:(39fd9c9) ✗
Happy Dockering!
Caveats on Mac OS (and possibly on Windows)
You are using Docker Machine to work with Docker. And so the IP address for Jekyll’s generated website is given by docker-machine ip dev where dev is the name of the Docker machine instance.
Also, you may face issues with not regenerating docs after your changes even when jekyll serve alone is supposed to work fine. It seems it does not with Docker on Mac OS. The workaround is to use jekyll serve --force_polling. The complete command line to have Jekyll running inside a Docker container with your changes being picked up is as follows:
docker run --rm -v $(pwd):/srv/jekyll -t --name=jekyll -p 4000:4000 jekyll/stable jekyll serve --force_polling
See https://github.com/jekyll/jekyll/issues/2926.
Let me know what you think about the topic of the blog post in the Comments section below or contact me at jacek@japila.pl. Follow the author as @jaceklaskowski on Twitter, too.