Everything you need to know about Container Runtime Security
Container orchestration systems like Kubernetes provide a simpler way to set up and manage containers at scale. As container adoption has increased, usage of these orchestration systems has skyrocketed. Kubernetes, for example, provides orchestration for more than three-quarters of containerized applications today. Of course, the popularity of these platforms makes them common targets for cyber criminals. Kubernetes combats this risk by offering pod security policies and drift management to help secure containers in development — but what happens when containers go to runtime?
While Docker and Kubernetes offer numerous tools for building security into containers, they don’t secure the runtime environment itself. As a result, a rich runtime stack of tools, processes, and policies has emerged that does the work of securing containers in production.
We’ll explain the risks around container runtime and the processes you can use to secure your containers in production.
The challenge of securing running containers
While practices like incorporating security into container builds and building smaller container images can help ensure no security problems are built into the container image, a number of threats can emerge once a container is running, including:
Newly discovered application vulnerabilities in old images
Configuration drift, such as changing user privileges without authorization
Privilege escalation attacks that allow bad actors to access secrets, storage volumes, or other resources
Deployment of containers using bugs in access control
Activation of malicious code that is written inside a container
Container monitoring tools like Prometheus and Grafana are often deployed to help improve the performance and efficiency of running containers, but these tools are not designed for security.
How to find and remediate container runtime risks
To secure running containers it’s essential to monitor key events such as log-ins, yet container runtime security goes beyond simple event monitoring. It starts with incorporating security into architecture using policy enforcement tools that set and enforce policies at the Kubernetes or kernel level. Scanning tools can then analyze audit logs, infrastructure as code (IaC), configuration settings, and application code itself to uncover new vulnerabilities or misconfigurations in production.
Who is responsible for container runtime security?
Responsibility for securing the application runtime has traditionally fallen to dedicated security teams. But the speed and complexity associated with agile and cloud native development means that developers are increasingly involved in addressing security risks within their code. They are shifting left to incorporate security into the earliest stages of planning and code.
Developer security responsibilities are also spreading across the container lifecycle from planning, coding, scanning, and deployment to the runtime environment. They now must also follow the development lifecycle forward and consider what happens when their containers go to runtime.
Choosing secure container engine runtime settings
Container engine runtime settings can be configured to limit attackers’ ability to spread their reach following a network breach. Here are a few suggested settings that will give your organization additional protection:
Don’t run as root
Containers should be run as users, not root. You can do this by first defining the user ID in the Dockerfile and then running as that user. This makes it easy to limit access using role-based access controls.
Default to read-only root filesystem settings
This prevents attackers from gaining control over a machine or writing malicious code to the host.
Limit access to container hosts
Disallow SSHing into servers. This helps prevent attackers and malware from escaping and attacking the host system.
Drop Linux capabilities
Capabilities allow fine-tuning of privileges on the kernel, such as the ability to read the audit log or bypass permission checks. Dropping Linux capabilities on a container limits the ability of attackers to manipulate the kernel.
Don’t run in privileged mode
Container runtimes include robust measures to shield containers from the host system. Running in privileged mode should be avoided as it circumvents most of these checks.
Scan the runtime using IaC scanning to detect misconfigurations
It is easy for developers to introduce misconfiguration issues as they set up their cloud infrastructure and container orchestrator. IaC scanning with Snyk IaC can automatically detect Kubernetes and other misconfigurations and deliver insights back to the tools within the developer workflow.
To learn more about runtime security settings, read our post, 10 Kubernetes Security Context settings you should understand | Snyk.
Sysdig + Snyk partnership for container runtime security
There’s no single solution or magic button to secure running containers, so it’s important to integrate security protocols wherever possible. The first priority is identifying where vulnerabilities and misconfigurations are and fixing the top issues. Security itself is a form of risk management, so it’s important to identify both vulnerabilities and their ramifications. Furthermore, it’s important to leverage Kubernetes’ tools and settings to boost container security posture.
While a fully automated container runtime security solution can catch most issues, the discerning eye of developers is still needed to fix security issues. Scanning tools can uncover vulnerabilities or misconfigurations in the runtime environment, but the developer still needs to circle back to the corresponding code to apply fixes. This wastes time and resources, and can result in developers overlooking an issue. That’s where Snyk comes in. Snyk addresses this by detecting issues — and recommending fixes — within developer workflows. Tools like Snyk Container and Kubernetes Configuration Security allow you to scan Docker containers and Kubernetes configurations and receive feedback within CI/CD tools.
Additionally, Snyk has partnered with Sysdig to bring that developer-first security thinking into the runtime environment. Sysdig’s runtime security uses open source Falco to detect intrusions, threats, and vulnerabilities in real time across containers and Kubernetes. The integration of Snyk and Sysdig allows these insights to go directly back to developer teams so they can prioritize and apply fixes.
Frequently asked questions
What is container runtime security?
Container runtime security refers to the tools and processes used to secure containers against threats and vulnerabilities once they hit production. Container runtime security strategies typically introduce a strong automation component, with developers and security teams handling container configurations and live environment scanning for vulnerabilities and configuration drift.
What is container runtime scanning?
Container runtime scanning is the use of tools and processes to scan containers in production. Scanning tools help uncover vulnerabilities or configuration issues, then automatically remediate or suggest fixes to developers. Using policy engines can help automate the process using detection rules, which the scanner can use to detect unexpected behavior or activity.
What is Kubernetes runtime security?
Kubernetes runtime security is the use of tools and processes to secure every component of the Kubernetes runtime environment. Developers can leverage Kubernetes’ built-in tools and settings to boost security, like the ability to control network ingress and egress to and from pods. Policy engines that integrate with Kubernetes using APIs allow tighter control of user behavior and network traffic. Finally, by using a runtime scanner, DevSecOps professionals can uncover new vulnerabilities and configuration drift in the live environment.
Are containers secure?
Containers are not secure out of the box, so it’s important for developers and security teams to incorporate container security from the start. Containers and applications are growing increasingly complex, so it’s not always feasible to expect developers to know every tool and process they can use to secure containers. Tools like Snyk and Sysdig allow developers to uncover threats directly within container code and the running environment. Insights about vulnerabilities and misconfigurations are then delivered to developers within their normal workflows.