GKE Autopilot Node Compromise via local-storage PersistentVolume

Date: Mar 1, 2021 03:14AM

Vulnerability Details

GKE Autopilot provides many default security controls to protect the node, including protections against privileged pods and limitations on hostPath volume mounts. However, these security configurations did not prevent PersistentVolumes with the "local-storage" storage class. The "local-storage" class can be used to mount files from the node into a pod, similar to hostPath volume mounts. This can be abused to mount sensitive files/directories from the node into a pod and elevate permissions. To demonstrate, we mount the /run path from the node, which contains docker.sock, and can be used to further compromise the node.

Use the following steps to reproduce:

  1. Create an Autopilot cluster
  2. Authenticate to the Autopilot cluster via gcloud container clusters get-credentials and verify kubectl get nodes succeeds
  3. (optionally create a user with limited access to create pods and persistent volumes, or use the "Kubernetes Engine Developer" role)
  4. Download the following files and place them in the working directory: exploit.sh docker.yaml
  5. Run the exploit.sh script which performs the following steps:
docker -H unix:///host/docker.sock run --rm -it --privileged --net=host --pid=host \
  alpine nsenter --mount=/proc/1/ns/mnt -- /bin/bash

Screenshot of the working exploit: Screenshot of the working exploit

Attack Scenario

The Autopilot documentation describes the motivation for its security controls as:

In order for GKE to offer management of the nodes and provide you with a more streamlined operational experience, there are a few restrictions and limitations when compared to GKE Standard. Some of these limitations are security best practices, while others allow Autopilot clusters to be safely managed.

A user with access to create pods and persistent volumes in the Autopilot cluster could bypass the security controls in the cluster and gain privileged access to the managed Kubernetes nodes. Using this access, they could read all secrets in the cluster (including those outside their provisioned access) or explore the attack surface of the Autopilot control plane. Additionally, this user can retrieve a service account token from the node metadata service for the default compute service account.

Timeline