Kubernetes is a system that manages containers (containerized applications) where a container could be explained as a lightweight virtual machine. To build an application you need to build a bunch of containers and then use Kubernetes to manage those containers.
A Kubernetes cluster has two main components—the control plane and data plane, machines used as compute resources :
-The control plane hosts the components used to manage the Kubernetes cluster.
-Worker nodes can be virtual machines (VMs) or physical machines. A node hosts pods, which run one or more containers.
Here are the main components of the control plane:
- kube-apiserver : Provides an API that serves as the front end of a Kubernetes control plane. It is responsible for handling external and internal requests—determining whether a request is valid and then processing it.
- kube-scheduler : This component is responsible for scheduling pods on specific nodes according to automated workflows and user defined conditions, which can include resource requests, concerns like affinity and taints or tolerations, priority, persistent volumes (PV), and more.
- kube-controller-manager : The controller manager is responsible for several controllers that handle various automated activities at the cluster or pod level, including replication controller, namespace controller, service accounts controller, deployment, statefulset, and daemonset.
- etcd : A key-value database that contains data about your cluster state and configuration. Etcd is fault tolerant and distributed.
- cloud-controller-manager : It enables you to connect a Kubernetes cluster with the API of a cloud provider.
Here are the main components of the Worker nodes:
- Nodes : Nodes are physical or virtual machines that can run pods as part of a Kubernetes cluster.
- Pods : A pod serves as a single application instance, and is considered the smallest unit in the object model of Kubernetes.
- Container Runtime Engine : Each node comes with a container runtime engine, which is responsible for running containers.
- kubelet : Each node contains a kubelet, which is a small application that can communicate with the Kubernetes control plane.
- kube-proxy : All compute nodes contain kube-proxy, a network proxy that facilitates Kubernetes networking services.
- Container Networking : Container networking enables containers to communicate with hosts or other containers.
Top comments (0)