Skip to content

Kubernetes Basics

A Kubernetes cluster consists of a set of worker machines, called nodes, that run containerized applications. The worker node(s) host the Pods that are the components of the application workload. The control plane manages the worker nodes and the Pods in the cluster. In production environments, the control plane usually runs across multiple computers and a cluster usually runs multiple nodes, providing fault-tolerance and high availability.

The kube-api-server, or API Server in short, is the brain of the Kubernetes cluster. In this lab, we'll be executing various Kubernetes commands/operations by using the powerful kubectl CLI which will talk to the API Server. It is possible to access the API Server via REST calls or officially supported client libraries but kubectl CLI is the most common and preferred way.

Kubernetes Architecture

Reference: Kubernetes Docs

Checking access to a Kubernetes cluster

kubectl version --short

If the above command returns the Kubernetes version, you're good to go. You're free to use any managed Kubernetes service or local Kubernetes installation for this lab.

Deploying a microservices app on Kubernetes

The following command creates a Kubernetes Deployment called dewans-app from dewandemo/authors image (which is on Docker Hub).

kubectl create deployment dewans-app --image=index.docker.io/dewandemo/authors:v1

One of the powerful feature of Kubernetes is the ability to scale your deployment up or down. The following command scales up dewans-app deployment to three repliacas.

kubectl scale deployment dewans-app --replicas=3

Execute the following command to view the running pods:

kubectl get pods

If you don't have any previous pods running on your system, you should see three pods running.

Self-healing of Kubernetes

From the output of the last command you ran, you should see a list like below:

dewans-app-cf48574d-6cssh      1/1     Running   0          10m
dewans-app-cf48574d-c97hr      1/1     Running   0          9m4s
dewans-app-cf48574d-pqssh      1/1     Running   0          9m4s

Delete one of the pods:

kubectl delete pods dewans-app-cf48574d-6cssh

After few moments, execute the following command and you should still see three running pods.

kubectl get pods

Kubernetes deleted one of the pods but the deployment ensures a replica of three at all times so another pod was spun up.

Updating the deployment with newer version of image

kubectl set image deployment/dewans-app authors=index.docker.io/dewandemo/authors:v2

This is how easily you can update a deployment to use a newer (or older) image.