Transfer “Controlling Access to the Kubernetes API” to the Concepts section

Readers from several different backgrounds will find it useful to know
about how Kubernetes controls access to its API. Promote this overview
to the Security subsection of Concepts.
pull/24534/head
Tim Bannister 2020-10-13 00:41:38 +01:00
parent 3edb970570
commit 78351ecaf5
13 changed files with 107 additions and 59 deletions

View File

@ -51,7 +51,7 @@ Before choosing a guide, here are some considerations:
* [Kubernetes Container Environment](/docs/concepts/containers/container-environment/) describes the environment for Kubelet managed containers on a Kubernetes node. * [Kubernetes Container Environment](/docs/concepts/containers/container-environment/) describes the environment for Kubelet managed containers on a Kubernetes node.
* [Controlling Access to the Kubernetes API](/docs/reference/access-authn-authz/controlling-access/) describes how to set up permissions for users and service accounts. * [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access) describes how Kubernetes implements access control for its own API.
* [Authenticating](/docs/reference/access-authn-authz/authentication/) explains authentication in Kubernetes, including the various authentication options. * [Authenticating](/docs/reference/access-authn-authz/authentication/) explains authentication in Kubernetes, including the various authentication options.

View File

@ -130,7 +130,7 @@ Adding an API does not directly let you affect the behavior of existing APIs (e.
### API Access Extensions ### API Access Extensions
When a request reaches the Kubernetes API Server, it is first Authenticated, then Authorized, then subject to various types of Admission Control. See [Controlling Access to the Kubernetes API](/docs/reference/access-authn-authz/controlling-access/) for more on this flow. When a request reaches the Kubernetes API Server, it is first Authenticated, then Authorized, then subject to various types of Admission Control. See [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access/) for more on this flow.
Each of these steps offers extension points. Each of these steps offers extension points.

View File

@ -131,7 +131,7 @@ Adding an API does not directly let you affect the behavior of existing APIs (e.
### API Access Extensions ### API Access Extensions
When a request reaches the Kubernetes API Server, it is first Authenticated, then Authorized, then subject to various types of Admission Control. See [Controlling Access to the Kubernetes API](/docs/reference/access-authn-authz/controlling-access/) for more on this flow. When a request reaches the Kubernetes API Server, it is first Authenticated, then Authorized, then subject to various types of Admission Control. See [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access/) for more on this flow.
Each of these steps offers extension points. Each of these steps offers extension points.

View File

@ -131,7 +131,7 @@ The Kubernetes API can be extended in one of two ways:
- Learn how to extend the Kubernetes API by adding your own - Learn how to extend the Kubernetes API by adding your own
[CustomResourceDefinition](/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions/). [CustomResourceDefinition](/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions/).
- [Controlling API Access](/docs/reference/access-authn-authz/controlling-access/) describes - [Controlling Access To The Kubernetes API](/docs/concepts/security/controlling-access/) describes
how the cluster manages authentication and authorization for API access. how the cluster manages authentication and authorization for API access.
- Learn about API endpoints, resource types and samples by reading - Learn about API endpoints, resource types and samples by reading
[API Reference](/docs/reference/kubernetes-api/). [API Reference](/docs/reference/kubernetes-api/).

View File

@ -140,13 +140,17 @@ For a complete example of authorizing a PodSecurityPolicy, see
### Troubleshooting ### Troubleshooting
- The [Controller Manager](/docs/reference/command-line-tools-reference/kube-controller-manager/) must be run - The [controller manager](/docs/reference/command-line-tools-reference/kube-controller-manager/)
against [the secured API port](/docs/reference/access-authn-authz/controlling-access/), must be run against the secured API port and must not have superuser permissions. See
and must not have superuser permissions. Otherwise requests would bypass [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access)
authentication and authorization modules, all PodSecurityPolicy objects would be to learn about API server access controls.
allowed, and users would be able to create privileged containers. For more details If the controller manager connected through the trusted API port (also known as the
on configuring Controller Manager authorization, see `localhost` listener), requests would bypass authentication and authorization modules;
[Controller Roles](/docs/reference/access-authn-authz/rbac/#controller-roles). all PodSecurityPolicy objects would be allowed, and users would be able to create grant
themselves the ability to create privileged containers.
For more details on configuring controller manager authorization, see
[Controller Roles](/docs/reference/access-authn-authz/rbac/#controller-roles).
## Policy Order ## Policy Order

View File

@ -4,7 +4,6 @@ reviewers:
- lavalamp - lavalamp
title: Controlling Access to the Kubernetes API title: Controlling Access to the Kubernetes API
content_type: concept content_type: concept
weight: 5
--- ---
<!-- overview --> <!-- overview -->
@ -12,7 +11,7 @@ This page provides an overview of controlling access to the Kubernetes API.
<!-- body --> <!-- body -->
Users [access the API](/docs/tasks/access-application-cluster/access-cluster/) using `kubectl`, Users access the [Kubernetes API](/docs/concepts/overview/kubernetes-api/) using `kubectl`,
client libraries, or by making REST requests. Both human users and client libraries, or by making REST requests. Both human users and
[Kubernetes service accounts](/docs/tasks/configure-pod-container/configure-service-account/) can be [Kubernetes service accounts](/docs/tasks/configure-pod-container/configure-service-account/) can be
authorized for API access. authorized for API access.
@ -21,45 +20,46 @@ following diagram:
![Diagram of request handling steps for Kubernetes API request](/images/docs/admin/access-control-overview.svg) ![Diagram of request handling steps for Kubernetes API request](/images/docs/admin/access-control-overview.svg)
## Transport Security ## Transport security
In a typical Kubernetes cluster, the API serves on port 443. In a typical Kubernetes cluster, the API serves on port 443, protected by TLS.
The API server presents a certificate. This certificate is The API server presents a certificate. This certificate may be signed using
often self-signed, so `$USER/.kube/config` on the user's machine typically a private certificate authority (CA), or based on a public key infrastructure linked
contains the root certificate for the API server's certificate, which when specified to a generally recognized CA.
is used in place of the system default root certificate. This certificate is typically
automatically written into your `$USER/.kube/config` when you create a cluster yourself If your cluster uses a private certificate authority, you need a copy of that CA
using `kube-up.sh`. If the cluster has multiple users, then the creator needs to share certifcate configured into your `~/.kube/config` on the client, so that you can
the certificate with other users. trust the connection and be confident it was not intercepted.
Your client can present a TLS client certificate at this stage.
## Authentication ## Authentication
Once TLS is established, the HTTP request moves to the Authentication step. Once TLS is established, the HTTP request moves to the Authentication step.
This is shown as step **1** in the diagram. This is shown as step **1** in the diagram.
The cluster creation script or cluster admin configures the API server to run The cluster creation script or cluster admin configures the API server to run
one or more Authenticator Modules. one or more Authenticator modules.
Authenticators are described in more detail [here](/docs/reference/access-authn-authz/authentication/). Authenticators are described in more detail in
[Authentication](/docs/reference/access-authn-authz/authentication/).
The input to the authentication step is the entire HTTP request, however, it typically The input to the authentication step is the entire HTTP request; however, it typically
just examines the headers and/or client certificate. just examines the headers and/or client certificate.
Authentication modules include Client Certificates, Password, and Plain Tokens, Authentication modules include client certificates, password, and plain tokens,
Bootstrap Tokens, and JWT Tokens (used for service accounts). bootstrap tokens, and JSON Web Tokens (used for service accounts).
Multiple authentication modules can be specified, in which case each one is tried in sequence, Multiple authentication modules can be specified, in which case each one is tried in sequence,
until one of them succeeds. until one of them succeeds.
On GCE, Client Certificates, Password, Plain Tokens, and JWT Tokens are all enabled.
If the request cannot be authenticated, it is rejected with HTTP status code 401. If the request cannot be authenticated, it is rejected with HTTP status code 401.
Otherwise, the user is authenticated as a specific `username`, and the user name Otherwise, the user is authenticated as a specific `username`, and the user name
is available to subsequent steps to use in their decisions. Some authenticators is available to subsequent steps to use in their decisions. Some authenticators
also provide the group memberships of the user, while other authenticators also provide the group memberships of the user, while other authenticators
do not. do not.
While Kubernetes uses `usernames` for access control decisions and in request logging, While Kubernetes uses usernames for access control decisions and in request logging,
it does not have a `user` object nor does it store usernames or other information about it does not have a `User` object nor does it store usernames or other information about
users in its object store. users in its API.
## Authorization ## Authorization
@ -101,16 +101,16 @@ If Bob makes a request to write (`create` or `update`) to the objects in the `pr
Kubernetes authorization requires that you use common REST attributes to interact with existing organization-wide or cloud-provider-wide access control systems. It is important to use REST formatting because these control systems might interact with other APIs besides the Kubernetes API. Kubernetes authorization requires that you use common REST attributes to interact with existing organization-wide or cloud-provider-wide access control systems. It is important to use REST formatting because these control systems might interact with other APIs besides the Kubernetes API.
Kubernetes supports multiple authorization modules, such as ABAC mode, RBAC Mode, and Webhook mode. When an administrator creates a cluster, they configured the authorization modules that should be used in the API server. If more than one authorization modules are configured, Kubernetes checks each module, and if any module authorizes the request, then the request can proceed. If all of the modules deny the request, then the request is denied (HTTP status code 403). Kubernetes supports multiple authorization modules, such as ABAC mode, RBAC Mode, and Webhook mode. When an administrator creates a cluster, they configure the authorization modules that should be used in the API server. If more than one authorization modules are configured, Kubernetes checks each module, and if any module authorizes the request, then the request can proceed. If all of the modules deny the request, then the request is denied (HTTP status code 403).
To learn more about Kubernetes authorization, including details about creating policies using the supported authorization modules, see [Authorization Overview](/docs/reference/access-authn-authz/authorization/). To learn more about Kubernetes authorization, including details about creating policies using the supported authorization modules, see [Authorization](/docs/reference/access-authn-authz/authorization/).
## Admission Control ## Admission control
Admission Control Modules are software modules that can modify or reject requests. Admission Control modules are software modules that can modify or reject requests.
In addition to the attributes available to Authorization Modules, Admission In addition to the attributes available to Authorization modules, Admission
Control Modules can access the contents of the object that is being created or modified. Control modules can access the contents of the object that is being created or modified.
Admission controllers act on requests that create, modify, delete, or connect to (proxy) an object. Admission controllers act on requests that create, modify, delete, or connect to (proxy) an object.
Admission controllers do not act on requests that merely read objects. Admission controllers do not act on requests that merely read objects.
@ -118,26 +118,26 @@ When multiple admission controllers are configured, they are called in order.
This is shown as step **3** in the diagram. This is shown as step **3** in the diagram.
Unlike Authentication and Authorization Modules, if any admission controller module Unlike Authentication and Authorization modules, if any admission controller module
rejects, then the request is immediately rejected. rejects, then the request is immediately rejected.
In addition to rejecting objects, admission controllers can also set complex defaults for In addition to rejecting objects, admission controllers can also set complex defaults for
fields. fields.
The available Admission Control Modules are described [here](/docs/reference/access-authn-authz/admission-controllers/). The available Admission Control modules are described in [Admission Controllers](/docs/reference/access-authn-authz/admission-controllers/).
Once a request passes all admission controllers, it is validated using the validation routines Once a request passes all admission controllers, it is validated using the validation routines
for the corresponding API object, and then written to the object store (shown as step **4**). for the corresponding API object, and then written to the object store (shown as step **4**).
## API Server Ports and IPs ## API server ports and IPs
The previous discussion applies to requests sent to the secure port of the API server The previous discussion applies to requests sent to the secure port of the API server
(the typical case). The API server can actually serve on 2 ports: (the typical case). The API server can actually serve on 2 ports:
By default the Kubernetes API server serves HTTP on 2 ports: By default the Kubernetes API server serves HTTP on 2 ports:
1. `Localhost Port`: 1. `localhost` port:
- is intended for testing and bootstrap, and for other components of the master node - is intended for testing and bootstrap, and for other components of the master node
(scheduler, controller-manager) to talk to the API (scheduler, controller-manager) to talk to the API
@ -148,7 +148,7 @@ By default the Kubernetes API server serves HTTP on 2 ports:
- request handled by admission control module(s). - request handled by admission control module(s).
- protected by need to have host access - protected by need to have host access
2. `Secure Port`: 2. “Secure port”:
- use whenever possible - use whenever possible
- uses TLS. Set cert with `--tls-cert-file` and key with `--tls-private-key-file` flag. - uses TLS. Set cert with `--tls-cert-file` and key with `--tls-private-key-file` flag.
@ -158,8 +158,27 @@ By default the Kubernetes API server serves HTTP on 2 ports:
- request handled by admission control module(s). - request handled by admission control module(s).
- authentication and authorization modules run. - authentication and authorization modules run.
When the cluster is created by `kube-up.sh`, on Google Compute Engine (GCE), ## {{% heading "whatsnext" %}}
and on several other cloud providers, the API server serves on port 443. On
GCE, a firewall rule is configured on the project to allow external HTTPS
access to the API. Other cluster setup methods vary.
Read more documentation on authentication, authorization and API access control:
- [Authenticating](/docs/reference/access-authn-authz/authentication/)
- [Authenticating with Bootstrap Tokens](/docs/reference/access-authn-authz/bootstrap-tokens/)
- [Admission Controllers](/docs/reference/access-authn-authz/admission-controllers/)
- [Dynamic Admission Control](/docs/reference/access-authn-authz/extensible-admission-controllers/)
- [Authorization](/docs/reference/access-authn-authz/authorization/)
- [Role Based Access Control](/docs/reference/access-authn-authz/rbac/)
- [Attribute Based Access Control](/docs/reference/access-authn-authz/abac/)
- [Node Authorization](/docs/reference/access-authn-authz/node/)
- [Webhook Authorization](/docs/reference/access-authn-authz/webhook/)
- [Certificate Signing Requests](/docs/reference/access-authn-authz/certificate-signing-requests/)
- including [CSR approval](/docs/reference/access-authn-authz/certificate-signing-requests/#approval-rejection)
and [certificate signing](/docs/reference/access-authn-authz/certificate-signing-requests/#signing)
- Service accounts
- [Developer guide](/docs/tasks/configure-pod-container/configure-service-account/)
- [Administration](/docs/reference/access-authn-authz/service-accounts-admin/)
You can learn about:
- how Pods can use
[Secrets](/docs/concepts/configuration/secret/#service-accounts-automatically-create-and-attach-secrets-with-api-credentials)
to obtain API credentials.

View File

@ -103,7 +103,7 @@ areas of security concerns and recommendations for securing workloads running in
Area of Concern for Workload Security | Recommendation | Area of Concern for Workload Security | Recommendation |
------------------------------ | --------------------- | ------------------------------ | --------------------- |
RBAC Authorization (Access to the Kubernetes API) | https://kubernetes.io/docs/reference/access-authn-authz/rbac/ RBAC Authorization (Access to the Kubernetes API) | https://kubernetes.io/docs/reference/access-authn-authz/rbac/
Authentication | https://kubernetes.io/docs/reference/access-authn-authz/controlling-access/ Authentication | https://kubernetes.io/docs/concepts/security/controlling-access/
Application secrets management (and encrypting them in etcd at rest) | https://kubernetes.io/docs/concepts/configuration/secret/ <br> https://kubernetes.io/docs/tasks/administer-cluster/encrypt-data/ Application secrets management (and encrypting them in etcd at rest) | https://kubernetes.io/docs/concepts/configuration/secret/ <br> https://kubernetes.io/docs/tasks/administer-cluster/encrypt-data/
Pod Security Policies | https://kubernetes.io/docs/concepts/policy/pod-security-policy/ Pod Security Policies | https://kubernetes.io/docs/concepts/policy/pod-security-policy/
Quality of Service (and Cluster resource management) | https://kubernetes.io/docs/tasks/configure-pod-container/quality-service-pod/ Quality of Service (and Cluster resource management) | https://kubernetes.io/docs/tasks/configure-pod-container/quality-service-pod/
@ -147,8 +147,8 @@ Learn about related Kubernetes security topics:
* [Pod security standards](/docs/concepts/security/pod-security-standards/) * [Pod security standards](/docs/concepts/security/pod-security-standards/)
* [Network policies for Pods](/docs/concepts/services-networking/network-policies/) * [Network policies for Pods](/docs/concepts/services-networking/network-policies/)
* [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access)
* [Securing your cluster](/docs/tasks/administer-cluster/securing-a-cluster/) * [Securing your cluster](/docs/tasks/administer-cluster/securing-a-cluster/)
* [API access control](/docs/reference/access-authn-authz/controlling-access/)
* [Data encryption in transit](/docs/tasks/tls/managing-tls-in-a-cluster/) for the control plane * [Data encryption in transit](/docs/tasks/tls/managing-tls-in-a-cluster/) for the control plane
* [Data encryption at rest](/docs/tasks/administer-cluster/encrypt-data/) * [Data encryption at rest](/docs/tasks/administer-cluster/encrypt-data/)
* [Secrets in Kubernetes](/docs/concepts/configuration/secret/) * [Secrets in Kubernetes](/docs/concepts/configuration/secret/)

View File

@ -1,4 +1,26 @@
--- ---
title: Accessing the API title: API Access Control
weight: 20 weight: 20
--- no_list: true
---
For an introduction to how Kubernetes implements and controls API access,
read [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access/).
Reference documentation:
- [Authenticating](/docs/reference/access-authn-authz/authentication/)
- [Authenticating with Bootstrap Tokens](/docs/reference/access-authn-authz/bootstrap-tokens/)
- [Admission Controllers](/docs/reference/access-authn-authz/admission-controllers/)
- [Dynamic Admission Control](/docs/reference/access-authn-authz/extensible-admission-controllers/)
- [Authorization](/docs/reference/access-authn-authz/authorization/)
- [Role Based Access Control](/docs/reference/access-authn-authz/rbac/)
- [Attribute Based Access Control](/docs/reference/access-authn-authz/abac/)
- [Node Authorization](/docs/reference/access-authn-authz/node/)
- [Webhook Authorization](/docs/reference/access-authn-authz/webhook/)
- [Certificate Signing Requests](/docs/reference/access-authn-authz/certificate-signing-requests/)
- including [CSR approval](/docs/reference/access-authn-authz/certificate-signing-requests/#approval-rejection)
and [certificate signing](/docs/reference/access-authn-authz/certificate-signing-requests/#signing)
- Service accounts
- [Developer guide](/docs/tasks/configure-pod-container/configure-service-account/)
- [Administration](/docs/reference/access-authn-authz/service-accounts-admin/)

View File

@ -17,7 +17,7 @@ policies using the supported authorization modules.
<!-- body --> <!-- body -->
In Kubernetes, you must be authenticated (logged in) before your request can be In Kubernetes, you must be authenticated (logged in) before your request can be
authorized (granted permission to access). For information about authentication, authorized (granted permission to access). For information about authentication,
see [Controlling Access to the Kubernetes API](/docs/reference/access-authn-authz/controlling-access/). see [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access/).
Kubernetes expects attributes that are common to REST API requests. This means Kubernetes expects attributes that are common to REST API requests. This means
that Kubernetes authorization works with existing organization-wide or that Kubernetes authorization works with existing organization-wide or

View File

@ -27,6 +27,9 @@ lists the API for Kubernetes version {{< param "version" >}}.
For general background information, read For general background information, read
[The Kubernetes API](/docs/concepts/overview/kubernetes-api/). [The Kubernetes API](/docs/concepts/overview/kubernetes-api/).
[Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access/)
describes how clients can authenticate to the Kubernetes API server, and how their
requests are authorized.
<!-- body --> <!-- body -->

View File

@ -149,9 +149,8 @@ certificate.
On some clusters, the apiserver does not require authentication; it may serve On some clusters, the apiserver does not require authentication; it may serve
on localhost, or be protected by a firewall. There is not a standard on localhost, or be protected by a firewall. There is not a standard
for this. [Configuring Access to the API](/docs/reference/access-authn-authz/controlling-access/) for this. [Controlling Access to the API](/docs/concepts/security/controlling-access)
describes how a cluster admin can configure this. Such approaches may conflict describes how a cluster admin can configure this.
with future high-availability support.
## Programmatic access to the API ## Programmatic access to the API

View File

@ -148,9 +148,8 @@ certificate.
On some clusters, the API server does not require authentication; it may serve On some clusters, the API server does not require authentication; it may serve
on localhost, or be protected by a firewall. There is not a standard on localhost, or be protected by a firewall. There is not a standard
for this. [Configuring Access to the API](/docs/reference/access-authn-authz/controlling-access/) for this. [Controlling Access to the Kubernetes API](/docs/concepts/security/controlling-access)
describes how a cluster admin can configure this. Such approaches may conflict describes how you can configure this as a cluster administrator.
with future high-availability support.
### Programmatic access to the API ### Programmatic access to the API

View File

@ -69,6 +69,7 @@
/docs/api-reference/labels-annotations-taints/ /docs/reference/labels-annotations-taints/ 301 /docs/api-reference/labels-annotations-taints/ /docs/reference/labels-annotations-taints/ 301
/docs/reference/using-api/api-overview/ /docs/reference/using-api/ 301 /docs/reference/using-api/api-overview/ /docs/reference/using-api/ 301
/docs/reference/access-authn-authz/controlling-access/ /docs/concepts/security/controlling-access/ 301
/docs/concepts/abstractions/controllers/garbage-collection/ /docs/concepts/workloads/controllers/garbage-collection/ 301 /docs/concepts/abstractions/controllers/garbage-collection/ /docs/concepts/workloads/controllers/garbage-collection/ 301
/docs/concepts/abstractions/controllers/statefulsets/ /docs/concepts/workloads/controllers/statefulset/ 301 /docs/concepts/abstractions/controllers/statefulsets/ /docs/concepts/workloads/controllers/statefulset/ 301
@ -449,7 +450,8 @@
/editdocs/ /docs/contribute/ 301 /editdocs/ /docs/contribute/ 301
/docs/home/editdocs/ /docs/contribute/ 301 /docs/home/editdocs/ /docs/contribute/ 301
/docs/admin/accessing-the-api/ /docs/reference/access-authn-authz/controlling-access/ 301
/docs/admin/accessing-the-api/ /docs/concepts/overview/kubernetes-api/ 301
/docs/admin/admission-controllers/ /docs/reference/access-authn-authz/admission-controllers/ 301 /docs/admin/admission-controllers/ /docs/reference/access-authn-authz/admission-controllers/ 301
/docs/admin/authentication/ /docs/reference/access-authn-authz/authentication/ 301 /docs/admin/authentication/ /docs/reference/access-authn-authz/authentication/ 301
/docs/admin/bootstrap-tokens/ /docs/reference/access-authn-authz/bootstrap-tokens/ 301 /docs/admin/bootstrap-tokens/ /docs/reference/access-authn-authz/bootstrap-tokens/ 301