Decouple GitHub Pages build from Nix using Docker

Projects like Ema enable creating your own static-site generator in Haskell, while leveraging Nix for reproducibility. The challenge with deploying your Haskell-based static site on GitHub Pages, however, is the lack of Nix caching. Every time you update your site, the CI will run slowly due to having to:

  • Download, and rebuild any Haskell dependencies overriden in the Nix file
  • Rebuild the static site Haskell project itself

Now, if you are scheduling generation of site (presumably because the input to your site is fetched afresh from the internet), then the above steps will re-run needlessly. This can be avoided by decoupling the build and generate steps.

The build step

The build step should run nix-build, effectively - and then use Nix’s docker infrastructure to produce a Docker image out of it and push it to a remote (Docker Hub or GitHub’s image registry).

Example

The generate step

The generate step of the CI would then use the latest Docker image from the registry and simply “run” your project. There is no compilation whastoever involved here, so it completes instantly.

Example

#blog