When compared to dynamic sites based on WordPress or Drupal, staticly generated blog and Web sites (like this one) can go a long way toward simplifying deployment and maintenance. There’s no database or server-side code to maintain, and, when paired with a service like Github or Gitlab, you can accept posts or other contributions from anyone, via pull request.
However, while simplifying certain areas, static sites introduce a bit more complexity in other areas. Among the handful of Middleman-based static sites that our team at Red Hat help maintain, we’ve seen the specter of “it works on my laptop” arise.
With Middleman, authors preview content on their local machine, using Middleman’s built-in development server. There isn’t much setup required to run this development server, but when the same Middleman code runs on different machines, with different operating systems, and different assortments of Ruby gems, things don’t always work as expected.
Enter Docker, which makes it easy to enforce a common application environment for users on different machines. Here’s how I’m using Docker to write and preview this post:
First, I’ll make sure that git and docker are installed on my Fedora 20 notebook, and I’ll add myself to the docker group on my machine.
sudo yum install -y git docker-io
sudo usermod -a -G docker $USER
For the group add to take effect, you must log out and back in, or run su - $USER
before continuing.
Then, I’ll cruise over to Github, make a fork of the Project Atomic Web site repo, and clone my new repo:
git clone git@github.com:jasonbrooks/atomic-site.git && cd atomic-site
There’s a script named docker.sh
in the repository that builds and runs a Docker container for running local development version of the projectatomic.io site.
I have a couple of modifications for the script and Dockerfile, which make it easier to viewing changes to the site as I write.
First, in the Dockerfile
included in the repo, I change the FROM line to FROM fedora:20
, which is the official Fedora image. If you’d prefer a CentOS image, you can change this line to FROM centos:centos7
. If you do, you’ll also need to add tar
and patch
to the list of packages to install in line 5.
I also remove line 11, ADD source /tmp/source
, because rather than roll the site source into my image, I’m going to point to the source directory in my checkout of the site. This way, I can add and edit posts without rebuilding the image.
Next, I edit the docker.sh
script included in the repo such that the docker run
command reads:
docker run -p 4567:4567 -v "$(pwd)"/source:/tmp/source:ro middleman
Finally, I modify the SELinux context of my checked-out source directory to allow my Docker container to read it:
chcon -Rt svirt_sandbox_file_t source/
To build and run the container, simply run:
sh docker.sh
After a short time (shorter, naturally, if you have an image already cached on your machine), the Middleman development server will be running on your machine at http://0.0.0.0:4567.
When you add to or edit the posts and other files within the source directory in your checked-out repo, you can refresh the page in your browser to see your changes.