Skip to content

Commit

Permalink
[Standardization] Baseline K8s cluster security (#415) (#376)
Browse files Browse the repository at this point in the history
* Kubernetes High Security setup (#415)

This commit adds a standard for high security setups, which should increase the overall of a Kubernetes cluster.

Signed-off-by: Hannes Baum <hannes.baum@cloudandheat.com>

* Grammar / spelling fixes.

Signed-off-by: Kurt Garloff <kurt@garloff.de>

* Fix small mistakes

Added some notes for the ports and shortened the motivation.

Signed-off-by: Hannes Baum <hannes.baum@cloudandheat.com>

* Baseline cluster security (#414)

Renamed the file to better match its actual intention.

Signed-off-by: Hannes Baum <hannes.baum@cloudandheat.com>

---------

Signed-off-by: Hannes Baum <hannes.baum@cloudandheat.com>
Signed-off-by: Kurt Garloff <kurt@garloff.de>
Co-authored-by: Kurt Garloff <kurt@garloff.de>
  • Loading branch information
cah-hbaum and garloff authored Feb 14, 2024
1 parent 337c073 commit 4c05b90
Show file tree
Hide file tree
Showing 2 changed files with 148 additions and 5 deletions.
10 changes: 5 additions & 5 deletions Standards/scs-0214-v1-k8s-node-distribution.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ track: KaaS
## Introduction

A Kubernetes instance is provided as a cluster, which consists of a set of machines,
so called nodes. A cluster is composed of a control plane and at least one worker node.
so-called nodes. A cluster is composed of a control plane and at least one worker node.
The control plane manages the worker nodes and therefore the pods in the cluster by making
decisions about scheduling, event detection and rights management. Inside the control plane,
multiple components exist, which can be duplicated and distributed over multiple nodes
Expand All @@ -19,11 +19,11 @@ separate the controller component from user workloads, which could pose a securi

The following terms are used throughout this document:

| Term | Meaning |
|---|---|
| Worker | Virtual or bare-metal machine, which hosts workloads of customers |
| Term | Meaning |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Worker | Virtual or bare-metal machine, which hosts workloads of customers |
| Control Plane | Virtual or bare-metal machine, which hosts the container orchestration layer that exposes the API and interfaces to define, deploy, and manage the lifecycle of containers. |
| Machine | Virtual or bare-metal entity with computational capabilities |
| Machine | Virtual or bare-metal entity with computational capabilities |

## Motivation

Expand Down
143 changes: 143 additions & 0 deletions Standards/scs-0217-v1-baseline-cluster-security.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
---
title: Kubernetes cluster baseline security
type: Standard
status: Draft
track: KaaS
---

## Introduction

Due to the regular changes and updates, there are always new security features to deploy and use in Kubernetes.
Nevertheless, a provider (or even a customer) needs to take action in order to achieve a
hardened, secure cluster due to the myriad of configurations possible. This is especially
the case since Kubernetes ships with insecure features and configurations out of the box,
which will need to be mitigated by an administrator with the proper knowledge.
Hardened, secure Kubernetes clusters are desirable regardless of the possible threat model,
since higher security doesn't necessarily mean higher complexity in this case.

## Terminology

| Term | Meaning |
|------|-----------------------------|
| TLS | Transport Layer Security |
| CA | Certificate Authority |
| CSR | Certificate Signing Request |

## Motivation

Kubernetes clusters are highly configurable, which also gives rise to different security
problems, if the configuration isn't done properly.
These security risks can potentially be exposed in many different parts of a cluster, e.g.
different APIs, authorization and authentication procedures or even Pod privilege mechanisms.
In order to mitigate these problems, different steps and mechanisms could be used to increase
the security of a Kubernetes setup.

## Design Considerations

### External CA

Kubernetes provides an API to provision TLS certificates that can be signed by a CA.
This CA can be controlled by the cluster provider, which enables much more tight control
over the clusters communication and therefore also better controllable security.

In order to do this, the CA certificate bundle needs to be added to the trusted certificates
of the server.
To provide a certificate, the following steps need to be undertaken:

1. Create a CSR
2. Send the CSR manifest to the k8s API
3. Approve the CSR
4. Sign CSR with your CA
5. Upload the signed certificate to the server

This certificate could now be used by a user in a pod in order to provide a trusted certificate.

It is also possible for the Kubernetes controller manager to provide the signing functionality.
To enable this, `--cluster-signing-cert-file` and `--cluster-signing-key-file` need to be set with
a reference to the CA keypair, which was used in the previous example to sign a CSR.

### Protected Kubernetes endpoints

In order to secure a Kubernetes cluster, the protection of endpoints is important.
To do this, different approaches can be taken.

#### TLS for all internal/API traffic

It is already expected by Kubernetes that all API communication internally is encrypted with TLS.
Nevertheless, some endpoints of internal components could be/will be exposed without the necessary
encryption, which could lead to weak points in the system.
A list of the default service endpoints can be seen in the following table

| Protocol | Port Range | Purpose | Notes |
|----------|-------------|-------------------------|-----------------------------------------------------------------------------------------|
| TCP | 6443* | Kubernetes API Server | - |
| TCP | 2379-2380 | etcd server client API | - |
| TCP | 10250 | Kubelet API | - |
| TCP | 10251/10259 | kube-scheduler | 10251 could be insecure before 1.13, after that only the secure port 10259 is available |
| TCP | 10252/10257 | kube-controller-manager | 10252 could be insecure before 1.13, after that only the secure port 10257 is available |
| TCP | 30000-32767 | NodePort Services | Service endpoints, could be HTTP |

The usage of `readOnlyPort` (enabling a read-only Kubelet API port on 10255) by design neither provides authentication nor authorization. Its usage is strongly discouraged!

#### Authentication and Authorization

All API clients should authenticate and authorize in order to be able to access an API or even
specific functions of this API. This is the case for users as well as internal components.

Most internal clients (like proxies or nodes) are typically authenticated via service accounts or
x509 certificates, which will normally be created automatically during the setup of a cluster.
External users can authenticate via an access pattern of choice, which is typically decided by
the cluster provider.

Authorization is (normally) done by the Role-Based Access Control (RBAC), which matches a request
by a user with a set of permissions, also called a role. Kubernetes deploys some roles out-of-the-box;
additional roles need to be carefully checked, since some permissions for specific resources allow
modification of other resources.

This whole process is especially important for the Kubelet, which allows anonymous requests in its
default configuration. This is obviously a security risk, since everybody with access to its endpoint
could manipulate resources that are managed with the Kubelet.

To disable anonymous requests, the Kubelet should be started with `--anonymous-auth=false`.
Authentication can be provided either through x509 client certificates or API bearer tokens.
How to set up both approaches can be found in the [Kubelet Authentication and Authorization](https://kubernetes.io/docs/reference/access-authn-authz/kubelet-authn-authz/).

Kubelet authorization is set to `AlwaysAllow` as a default mode. This can be quite problematic,
since all authenticated users can do all actions. To mitigate this, it is possible to delegate
authorization to the API server by:

- enabling the `authorization.k8s.io/v1beta1` API group
- starting the Kubelet with the `--authorization-mode=Webhook` and the `--kubeconfig` flags

After that, the Kubelet calls the `SubjectAccessReview` API in order to determine the authorization of a request.

## Decision

This standard tries to increase security for a Kubernetes cluster in order to provide a
solid baseline setup with regard to security. For this to work, multiple measures need to be undertaken.

A self-controlled CA SHOULD be used in order to be in control of the TLS certificates, which
enables operators to provide and revoke certificates according to their own requirements.

All internal endpoints found in the section [TLS for all internal/API traffic] MUST be
encrypted with TLS in order to secure internal traffic.

The Kubernetes API (kubeAPI) MUST be secured by authenticating and authorizing the users
trying to access its endpoints. How a user is authenticated is up to the provider of the
cluster and/or the wishes of the customer. Authorization MUST be done by providing fine-grained RBAC.
The authentication and authorization steps MUST also be applied to the Kubelet, which in its default configuration
doesn't enable them. A way to do this can be found in the section [Authentication and Authorization].

## Related Documents

- [Managing TLS in a cluster](https://kubernetes.io/docs/tasks/tls/managing-tls-in-a-cluster/)
- [Securing a cluster](https://kubernetes.io/docs/tasks/administer-cluster/securing-a-cluster/)
- [Controlling access](https://kubernetes.io/docs/concepts/security/controlling-access/)
- [Kubernetes Security Checklist](https://kubernetes.io/docs/concepts/security/security-checklist/)
- [Kubelet Authentication and Authorization](https://kubernetes.io/docs/reference/access-authn-authz/kubelet-authn-authz/)
- [Authentication](https://kubernetes.io/docs/reference/access-authn-authz/authentication/)
- [OWASP Kubernetes Security Cheat Sheet](https://cheatsheetseries.owasp.org/cheatsheets/Kubernetes_Security_Cheat_Sheet.html)

## Conformance Tests

Conformance Tests will be written in another issue

0 comments on commit 4c05b90

Please sign in to comment.