My original plan was to stabilize my VM pipeline before deploying containers using a hardened stack of Podman, QEMU, SELinux, and user namespaces (--userns=auto
). However, the pipeline's complexity grew, requiring script rewrites and schema redesigns, and the process took much longer than anticipated.
In the meantime, an interesting alternative has captured my attention: gVisor. It occupies a unique space between traditional SELinux policies and full-blown virtual machines, offering a compelling set of trade-offs.
What is gVisor?
At its core, gVisor is an application kernel, written in the memory-safe language Go, that provides an additional layer of isolation between containerized applications and the host operating system. It's essentially a user-space implementation of the Linux kernel's system call interface.
The security model is explained here.
gVisor in Practice
gVisor provides an OCI-compliant runtime called runsc
, which can be almost transparently integrated with container tools like Docker and Podman.
And that's it! Unlike SELinux, here we don't need to write any policies. This is the most attractive feature for me.
However, it comes with notable downsides:
- SELinux is not supported, I cannot use both gVisor and SELinux at the same time.
--ignore-cgroups
must be used for rootless podman, this mean cgroups won't work. Maybe it can be fixed later.- There can be potential compatibily issues, because gVisor implements its own version of syscalls.
- The performance overhead is higher, especially for IO-related syscalls. It is well explain here.
My Plan
I plan to evaluate gVisor with a few of my simple containers. Its promise of "secure-by-default" sandboxing without complex configuration is very appealing, especially for running applications where trust is a concern but the overhead of a full VM is undesirable.
I also believe that I don't really need the fine-grained control offered by SELinux. Bind mounts (read-only, read-write) should be enough for me. Eventually I might even drop the VM pipeline and just use gVisor.
We'll see.
Comments