On-entry container attack - CVE-2016-9962

Public Date: January 10, 2017, 12:49
Updated October 24, 2024, 11:56 - Chinese, Simplified French Japanese Korean

Was this information helpful?

Resolved Status
Important Impact

A container on-entry vulnerability was found in docker and has been assigned CVE-2016-9962. The flaw addresses a specific attack that uses ptrace and improperly-flushed file descriptors to gain access to content outside a container. This attack is only a risk when running privileged containers and is mitigated by SELinux.

This issue was publicly disclosed on January 10, 2017.

This vulnerability arises when a process that would normally run in one namespace is launched or moved into a different namespace. Namespaces normally act as a security mechanism because processes within different namespaces cannot see or manipulate one another. The problem is that when a process is moved into a namespace, it becomes exposed to malicious actions from processes that are already in that namespace. On-entry vulnerabilities attack processes that join containers via nsenter or docker exec . A successful attack can result in a malicious process gaining system access or other privileges.

For example, if a malicious process has taken over a container and managed to obtain root within that container, the malicious process can kill any other process it can "see". Fortunately, container namespacing keeps the malicious process from being able to detect or kill any host processes or any of the processes in other containers. However, if an administrator attempts to investigate the issue by using nsenter to move a shell into the misbehaving container, the malicious process can see and manipulate that shell as well (and terminate it).

The following legitimate Linux facilities can be misused in on-entry attacks. Use Linux security mechanisms such as SELinux and seccomp to prevent their exploitation.

  • ptrace
    "Process trace" or ptrace is a powerful debugging facility that is available in Linux. Any process with adequate permissions can ptrace another process through the ptrace kernel call. ptrace grants extremely low-level access to the process, including its memory, resources (such as file descriptors), and the ability to intercept process kernel calls.
  • docker exec
    docker exec is a service provided by the docker daemon that allows an additional process to be launched within an existing container. This is often used to inspect or make manual changes to the container. For example, to launch a bash shell within a misbehaving container in order to debug its behavior, you could use:
    docker exec -it container-name /bin/bash
  • nsenter
    nsenter is a Linux utility used to move or launch processes within specific namespaces. Because containers are built on Linux namespaces, nsenter can be used as a more generic version of docker exec .
  • kernel capabilities
    In Linux, the special powers traditionally granted to the root account have been split into individual capabilities, and some grant more than one administrative power. For example, CAP_SYS_TIME grants only the ability to set the system clock. CAP_SYS_ADMIN , on the other hand, grants the range of powers needed to administer a machine. Each kernel capability can be granted or denied to a process individually.
  • seccomp
    The seccomp Linux facility allows access to kernel calls on an individual basis.

Red Hat Product Security has rated this update as having a security impact of Important .

The following Red Hat Product versions are impacted:

  • Red Hat Enterprise Linux 7
  • Red Hat Openshift Container Platform
  • RHEL Atomic Host

The flaw in CVE-2016-9962 occurs because a safety mechanism is missing from docker exec .

Until upstream docker 1.12.6, processes that docker exec launched could be ptrace 'd within the container and they briefly kept their file descriptors, which were linked to content outside the container. This could be exploited by a process within a container equipped with ptrace abilities. If a malicious process acted quickly enough, it could ptrace the incoming process and gain access to content outside the container. This has been addressed in docker 1.12.6 by preventing `ptrace`ing of these processes (through the DUMPABLE process attribute) and by having incoming processes flush their file descriptors before being moved.

Even without the backport, most installations are not at risk:

  • On Red Hat systems with SELinux enabled, the dangers of even privileged containers are mitigated. SELinux prevents container processes from accessing host content even if those container processes manage to gain access to the actual file descriptors.
  • In most installations, nsenter and docker exec are purely manual operations. OpenShift uses nsenter to facilitate port-forwarding, but without manual intervention, vanilla docker will never move a process into a container or between containers.
To check whether your docker version already has the backported fix, download and use this script .

All Red Hat customers running the affected versions of docker are recommended to update when patches are available. Details about impacted packages as well as recommended mitigation are noted below.

ProductPackageAdvisory/Update
Red Hat Enterprise Linux 7docker-latest, docker, runcRHSA-2017-0116 ,  RHSA-2017-0123 ,  RHSA-2017-0127
Red Hat Openshift Container Hostdocker-latest, dockerpatch applied
RHEL Atomic Hostdocker-latest, docker, runcpatch applied 

ptrace and other dangerous kernel calls can be banned from your containers. Custom seccomp profiles can be created to forbid this behaviour (supported by vanilla docker, OpenShift, and Kubernetes). This will completely prevent attacks based on CVE-2016-9962.

Comments