Buildah and podman make a great pair for building, managing and running containers on a Linux system. You can even use them with GitLab CI with a few small adjustments, namely the switch from the overlayfs to vfs storage driver.
I have some regularly scheduled GitLab CI jobs that attempt to build fresh containers each morning and I use these to get the latest packages and find out early when something is broken in the build process. A failed build appeared in my inbox earlier this week with the following error:
+ buildah bud -f builds/builder-fedora30 -t builder-fedora30 . vfs driver does not support overlay.mountopt options
My container build script is fairly basic, but it does include a change to use the vfs storage driver:
# Use vfs with buildah. Docker offers overlayfs as a default, but buildah # cannot stack overlayfs on top of another overlayfs filesystem. export STORAGE_DRIVER=vfs
The script doesn’t change any mount options during the build process. A quick
glance at the
/etc/containers/storage.conf revealed a possible problem:
[storage.options] # Storage options to be passed to underlying storage drivers # mountopt specifies comma separated list of extra mount options mountopt = "nodev,metacopy=on"
These mount options make sense when used with an overlayfs filesystem, but
they are not used with vfs. I commented out the
mountopt option, saved the
file, and ran a test build locally. Success!
Fixing the build script involved a small change to the
before building the container:
# Use vfs with buildah. Docker offers overlayfs as a default, but buildah # cannot stack overlayfs on top of another overlayfs filesystem. export STORAGE_DRIVER=vfs # Newer versions of podman/buildah try to set overlayfs mount options when # using the vfs driver, and this causes errors. sed -i '/^mountopt =.*/d' /etc/containers/storage.conf
My containers are happily building again in GitLab.