The Kubernetes API is served by the Kubernetes APIServer process. Typically, there is one of these running on a single kubernetes-master node.
By default the Kubernetes APIserver serves HTTP on 3 ports:
- Localhost Port
- serves HTTP
- default is port 8080, change with
-port
flag. - defaults IP is localhost, change with-address
flag. - no authentication or authorization checks in HTTP - protected by need to have host access - ReadOnly Port
- default is port 7080, change with
-read_only_port
- default IP is first non-localhost network interface, change with-public_address_override
- serves HTTP - no authentication checks in HTTP - only GET requests are allowed. - requests are rate limited - Secure Port
- default is port 6443, change with
-secure_port
- default IP is first non-localhost network interface, change with-public_address_override
- serves HTTPS. Set cert with-tls_cert_file
and key with-tls_private_key_file
. - uses token-file based authentication. - uses policy-based authorization.
Additionally, in typical configurations (i.e. GCE), there is a proxy (nginx) running on the same machine as the apiserver process. The proxy serves HTTPS protected by Basic Auth on port 443, and proxies to the apiserver on localhost:8080. Typically, firewall rules will allow HTTPS access to port 443.
The above are defaults and reflect how Kubernetes is deployed to GCE using kube-up.sh. Other cloud providers may vary.
There are three differently configured serving ports because there are a variety of uses cases:
- Clients outside of a Kubernetes cluster, such as human running
kubectl
on desktop machine. Currently, accesses the Localhost Port via a proxy (nginx) running on thekubernetes-master
machine. Proxy uses Basic Auth. - Processes running in Containers on Kubernetes that need to do read from the apiserver. Currently, these can use Readonly Port.
- Scheduler and Controller-manager processes, which need to do read-write API operations. Currently, these have to run on the operations on the apiserver. Currently, these have to run on the same host as the apiserver and use the Localhost Port.
- Kubelets, which need to do read-write API operations and are necessarily on different machines than the apiserver. Kubelet uses the Secure Port to get their pods, to find the services that a pod can see, and to write events. Credentials are distributed to kubelets at cluster setup time.
- Policy will limit the actions kubelets can do via the authed port.
- Kube-proxy currently uses the readonly port to read services and endpoints, but will eventually use the auth port.
- Kubelets may change from token-based authentication to cert-based-auth.
- Scheduler and Controller-manager will use the Secure Port too. They will then be able to run on different machines than the apiserver.
- A general mechanism will be provided for giving credentials to pods.
- The Readonly Port will no longer be needed and will be removed.
- Clients, like kubectl, will all support token-based auth, and the Localhost will no longer be needed, and will not be the default. However, the localhost port may continue to be an option for installations that want to do their own auth proxy.