Kubernetes PDF
Kubernetes PDF
Kubernetes PDF
• API Server
Kubernetes is an API server which provides all the operation on cluster using the API. API server
implements an interface, which means different tools and libraries can readily communicate with it.
• Controller Manager
This component is responsible for most of the collectors that regulates the state of cluster and
performs a task. In general, it can be considered as a daemon which runs in nonterminating loop
and is responsible for collecting and sending information to API server.
Kubernetes - Master Machine Components:
• Scheduler
This is one of the key components of Kubernetes master. It is a service in master responsible for
distributing the workload. It is responsible for tracking utilization of working load on cluster nodes
and then placing the workload on which resources are available and accept the workload. In
other words, this is the mechanism responsible for allocating pods to available nodes. The
scheduler is responsible for workload utilization and allocating pod to new node.
• etcd
It stores the configuration information which can be used by each of the nodes in the cluster. It is a
high availability key value store that can be distributed among multiple nodes. It is accessible only
by Kubernetes API server as it may have some sensitive information. It is a distributed key value
Store which is accessible to all.
Kubernetes - Master Machine Components:
Docker
The first requirement of each node is Docker which helps in running the encapsulated
application containers in a relatively isolated but lightweight operating environment.
Kubelet Service
This is a small service in each node responsible for relaying information to and from control
plane service. It interacts with etcd store to read configuration details and wright values. This
communicates with the master component to receive commands and work. The kubelet
process then assumes responsibility for maintaining the state of work and the node server.
Kubernetes - Node Components:
kube-proxy
To manage individual host subnetting and make services available to other components, a small
proxy service called kube-proxy is run on each node server. This process forwards requests to the
correct containers, can do primitive load balancing, and is generally responsible for making sure
the networking environment is predictable and accessible, but isolated where appropriate.
Pods
Containers are themselves contained in objects called pods. Pods are made up of one or more
containers that work together and share a life cycle on the same node. For example, a pod may
consist of a main container that runs the application server and a helper container responsible for
retrieving files when it detects changes to external repositories. Kubernetes clusters manage each
pod as a single unit
Kubernetes - Node Components:
Deployments
Deployments are the high-level objects that developers work with directly to manage the life
cycles of pods. They describe the desired state of an application. When deployments get
modified, Kubernetes automatically adjusts all replica sets, which makes it possible to perform
updates without affecting application availability
Services
Pods are only accessible within their Kubernetes cluster, so to make your applications available
to the outside word, pods must be exposed as services. A Kubernetes service groups together
related pods and presents them to end users as a single entity