kind - Creating a Kubernetes Cluster - Part 1

kind - Creating a Kubernetes Cluster - Part 1

In this article we will look how we can create a local Kubernetes cluster using kind

·

2 min read

Introduction

  • Kubernetes has become the de facto standard for container orchestration in the modern cloud-computing world

  • kind (Kubernetes in Docker) is a tool to create Kubernetes clusters running inside Docker containers

  • Mainly used for testing and local development purposes

  • Uses the same tooling and configuration as a production Kubernetes cluster

Features

  • Cost-effective — No need to worry about cloud bills

  • Flexibility — No need to worry about breaking things

  • Fast iteration — Easily test new features

Installation

  • Spin up a Linux machine, here I’m using Ubuntu 20.04.6 LTS
$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 20.04.6 LTS
Release: 20.04
Codename: focal
  • Install Docker using the convenience script
$ curl -fsSL https://get.docker.com -o get-docker.sh

$ sudo sh get-docker.sh
  • Add your user to the Docker group, log out and log back in. Now you can execute Docker commands as a normal user
$ sudo usermod -aG docker $USER
  • Download and install kind binary from the releases page
$ wget https://github.com/kubernetes-sigs/kind/releases/download/v0.18.0/kind-linux-amd64

$ sudo install kind-linux-amd64 /usr/local/bin/kind
$ kind version
kind v0.18.0 go1.20.2 linux/amd64
  • Download and install kubectl binary
$ curl -LO https://dl.k8s.io/release/v1.26.3/bin/linux/amd64/kubectl

$ sudo install kubectl /usr/local/bin/kubectl
$ kubectl version --client --output yaml
clientVersion:
  buildDate: "2023-03-15T13:40:17Z"
  compiler: gc
  gitCommit: 9e644106593f3f4aa98f8a84b23db5fa378900bd
  gitTreeState: clean
  gitVersion: v1.26.3
  goVersion: go1.19.7
  major: "1"
  minor: "26"
  platform: linux/amd64
kustomizeVersion: v4.5.7

Usage

  • Creating a cluster
$ kind create cluster --name dev
Creating cluster "dev" ...
 ✓ Ensuring node image (kindest/node:v1.26.3) 🖼 
 ✓ Preparing nodes 📦  
 ✓ Writing configuration 📜 
 ✓ Starting control-plane 🕹️ 
 ✓ Installing CNI 🔌 
 ✓ Installing StorageClass 💾 
Set kubectl context to "kind-dev"
You can now use your cluster with:

kubectl cluster-info --context kind-dev
  • Interacting to cluster
$ kubectl config use-context kind-dev 
Switched to context "kind-dev".
$ kubectl get nodes
NAME                STATUS   ROLES           AGE   VERSION
dev-control-plane   Ready    control-plane   10m   v1.26.3
  • Deploying workload to cluster
$ kubectl run nginx --image=nginx --port=80
pod/nginx created
$ kubectl get pods
NAME    READY   STATUS    RESTARTS   AGE
nginx   1/1     Running   0          22s
  • Deleting cluster
$ kind delete cluster --name dev
Deleting cluster "dev" ...
Deleted nodes: ["dev-control-plane"]

Reference

https://kind.sigs.k8s.io