This document describes security vulnerabilities / CVEs that may impact the security of Sysbox containers.
These may be vulnerabilities in Sysbox itself (which are fixed quickly), in CRI-O (when Sysbox is installed in Kubernetes clusters), or in the Linux kernel.
CVE | Date | Severity | Affects Sysbox | Details |
---|---|---|---|---|
2022-0811 | 03/15/22 | High | Yes | CVE-2022-0811 (Privilege Escalation in CRI-O via sysctl) |
2022-0847 | 03/03/22 | High | Yes | CVE-2022-0847 (Privilege Escalation via Pipes (aka Dirty Pipe)) |
2022-0492 | 02/06/22 | Medium | No | CVE 2022-0492 (Privilege Escalation via Cgroups v1) |
2022-0185 | 01/21/22 | High | Yes | CVE 2022-0185 (User-Namespace Escape) |
The sections below describe each of these in more detail.
Date: 01/21/22
Severity: High
Problem:
CVE 2022-0185 is a vulnerability in the Linux kernel which permits a "User Namespace" escape (i.e., an unprivileged user inside a user-namespace may gain root access on the host).
Effect on Sysbox:
This vulnerability can negate the extra isolation of containers deployed with Sysbox as they always use the Linux user-namespace.
Fix:
The fix has been committed to the Linux kernel on 01/18/22 and picked up by several distros shortly after. For Ubuntu, the fix has been released and requires a kernel update.
We recommend you upgrade your kernel (i.e., check if your kernel distro carries the fix and if so, apply it).
Date: 02/06/22
Severity: Medium
Problem:
CVE 2022-0492 is a flaw in the Linux kernel's cgroups mechanism that under some circumstances allows the use of the cgroups v1 release_agent feature to escalate privileges. It affects containers in some cases, as described in this excellent article by Unit 42 at Palo Alto Networks.
Effect on Sysbox:
Sysbox is NOT vulnerable to the security flaw exposed by this CVE. The reason is that inside a Sysbox container the cgroups v1 release_agent can't be written to (by virtue of Sysbox setting up the container with the Linux user-namespace). Even if you create privileged containers inside a Sysbox container, they won't be vulnerable due to the Sysbox container's usage of the Linux user-namespace.
Fix:
CVE-2022-0492 is fixed on the latest Linux release. Even though this CVE does not affect Sysbox containers, it does affect regular containers under some scenarios. Therefore we recommend that you check when your Linux distro picks up the fix and apply it.
Date: 03/03/22
Severity: High
Problem:
A flaw in the Linux pipes mechanism allows privilege escalation. Even a process whose user-ID is "nobody" can elevate its privileges.
Effect on Sysbox:
This vulnerability affects containers deployed with Sysbox as it voids the protection provided by the Linux user-namespace (where processes in the container run as "nobody:nogroup" at host level).
Fix:
The vulnerability first appeared in Linux kernel version 5.8, which was released in 08/2020. The vulnerability was fixed on 02/21/22 via this commit and available in kernel versions 5.16.11, 5.15.25, and 5.10.102.
We recommend you check when your Linux distro picks up the fix and apply it.
Date: 03/15/22
Severity: High
Problem:
CVE 2022-0811 is a vulnerability that affects the CRI-O runtime. Since installing Sysbox on Kubernetes clusters currently installs CRI-O, such clusters may be vulnerable.
The vulnerability allows a user with rights to deploy pods on the Kubernetes
cluster to achieve container escape and get root access to the underlying node,
using a flaw in the way CRI-O parses the pod's sysctl
securityContext. Refer
to the CVE description for full details.
Fix:
The version of sysbox-deploy-k8s released after 04/12/22 carries a CRI-O binary that has been patched to fix this problem. This commit in CRI-O has the fix.
To ensure you have the fix, check that your sysbox-deploy-k8s has a
sysbox-install.yaml that
points to image registry.nestybox.com/nestybox/sysbox-deploy-k8s:v0.5.1
(or
later). Alternatively, check the version of Sysbox in your Kubernetes nodes is
v0.5.1 or later (e.g., run systemctl status sysbox
on the K8s node).
If you have a prior version of Sysbox installed in your cluster, then your CRI-O is vulnerable. In this case we recommend upgrading the Sysbox version on your Kubernetes cluster, using the steps described here.