Reduce blast radius: Preventing forgotten roots¶
Note
This section helps you implement ISO 27001, specifically:
- A.9.4.4 Use of Privileged Utility Programmes
- A.12.6.1 Management of Technical Vulnerabilities
- A.14.2.5 Secure System Engineering Principles
Important
This guardrail is enabled by default and will deny violations. As a result, resources that violate this policy will not be created.
Many container runtimes and operating system vulnerabilities need code running as root to become a threat. To minimize this risk, application should only run as root when strictly necessary.
Unfortunately, many Dockerfiles -- and container base images -- today are shipped running as root by default. This makes it easy to slip code running as root into production, exposing data to unnecessary risks.
To reduce blast radius, Welkin will protect you from accidentally deploying application running as root.
How to solve: CreateContainerConfigError¶
You may encounter the following issue:
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
myapp-welkin-user-demo-564f8dd85-2bs8r 0/1 CreateContainerConfigError 0 84s
myapp-welkin-user-demo-bfbf9c459-dmk4l 0/1 CreateContainerConfigError 0 13m
$ kubectl describe pods myapp-welkin-user-demo-564f8dd85-2bs8r
[...]
Error: container has runAsNonRoot and image has non-numeric user (node), cannot verify user is non-root (pod: "myapp-welkin-user-demo-bfbf9c459-dmk4l_demo1(1b53b1a8-4845-4db5-aecf-6bebcc54e396)", container: welkin-user-demo)
This means that your Dockerfile uses a non-numeric user and Kubernetes cannot validate whether the image truly runs as non-root.
Alternatively, you may get:
$ kubectl describe pods myapp-welkin-user-demo-564f8dd85-2bs8r
[...]
Error: container has runAsNonRoot and image will run as root (pod: "myapp-welkin-user-demo-564f8dd85-2bs8r_demo1(a55a25f3-7b77-4fae-9f92-11e264446ecc)", container: welkin-user-demo)
This means that your Dockerfile has no USER
directive and your application would run as root.
To ensure your application does not run as root, you have two options:
- Change the Dockerfile to
USER 1000
or whatever numeric ID corresponds to your user. This is what the user demo does. -
Add the following snippet to the
spec
of your Pod manifest:securityContext: runAsUser: 1000
If possible, prefer changing the Dockerfile, to ensure your application runs as non-root not only in production, but also during development and testing. The smaller the difference between development, testing and production, the fewer surprises down the time.