Tell me for any kind of development solution

Edit Template

How to Install Kubernetes on Ubuntu: Step-by-Step Guide

Kubernetes is the backbone of modern container orchestration, automating deployments, scaling, and managing containerized applications. Whether you’re building a production cluster or experimenting locally, this guide walks you through two proven methods to install Kubernetes on Ubuntu: kubeadm for multi-node clusters and Minikube for local development. Let’s get started!

Why Use Kubernetes on Ubuntu?

Ubuntu’s simplicity, robust package management, and compatibility with cloud-native tools make it a top choice for Kubernetes. Key benefits include:

  • Seamless integration with Docker and containerd.
  • Optimized performance for cloud and on-premises setups.
  • Active community support for troubleshooting.

Prerequisites

  • Ubuntu 22.04 LTS (or newer).
  • 2+ CPU cores and 4+ GB RAM.
  • sudo privileges and stable internet connection.
  • Swap disabled (Kubernetes won’t work with swap enabled).

Disable Swap Permanently:

sudo swapoff -a 
sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab 

Method 1: Install Kubernetes on Ubuntu with kubeadm

Step 1: Update System Packages

Ensure your system is up to date:

sudo apt update && sudo apt upgrade -y 

Step 2: Install Docker Container Runtime

Kubernetes requires a container runtime. Install Docker:

sudo apt install -y docker.io 

Enable and Start Docker:

sudo systemctl enable docker && sudo systemctl start docker 

Step 3: Add Kubernetes Repository

Install dependencies and add the Kubernetes GPG key:

sudo apt install -y apt-transport-https ca-certificates curl 
curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.29/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg 
echo 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.29/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.list 

Step 4: Install Kubernetes Tools

Install kubelet, kubeadm, and kubectl:

sudo apt update 
sudo apt install -y kubelet kubeadm kubectl 

Prevent Automatic Updates:

sudo apt-mark hold kubelet kubeadm kubectl 

Step 5: Initialize the Control Plane

Create a Kubernetes master node:

sudo kubeadm init --pod-network-cidr=10.244.0.0/16 

Set Up User Access:

mkdir -p $HOME/.kube 
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config  
sudo chown $(id -u):$(id -g) $HOME/.kube/config 

Step 6: Install a Pod Network Add-On

Deploy Flannel for internal networking:

kubectl apply -f https://github.com/flannel-io/flannel/releases/latest/download/kube-flannel.yml 

Verify Node Status:

kubectl get nodes 

Step 7: Join Worker Nodes (Optional)

Use the kubeadm join command from the master node’s output to add workers:

sudo kubeadm join <MASTER_IP>:6443 --token <TOKEN> --discovery-token-ca-cert-hash <HASH> 

Method 2: Install Kubernetes on Ubuntu with Minikube

Minikube is perfect for local development and testing.

Step 1: Install Dependencies

Install VirtualBox and curl:

sudo apt install -y virtualbox curl 

Step 2: Install Minikube

Download and configure Minikube:

curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 
sudo install minikube-linux-amd64 /usr/local/bin/minikube 

Step 3: Install kubectl

Download the Kubernetes CLI tool:

curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" 
sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl 

Step 4: Start Minikube Cluster

Launch a single-node cluster:

minikube start --driver=virtualbox 

Verify Cluster Status:

kubectl get pods -A 

Post-Installation Best Practices

Enable Kubernetes Dashboard (Minikube):

minikube dashboard 

Deploy a Sample App:

kubectl create deployment hello-world --image=nginx 
kubectl expose deployment hello-world --port=80 --type=NodePort 

Monitor Resources:

kubectl top nodes 

Troubleshooting Common Issues

1. kubeadm init Fails

Fix: Ensure Docker is running and swap is disabled.

2. Pods Stuck in “Pending” State

Fix: Verify the network add-on (e.g., Flannel/Calico) is installed.

3. Minikube Startup Errors

Fix: Restart Minikube with minikube delete && minikube start.


Conclusion

You’ve now installed Kubernetes on Ubuntu using kubeadm for scalable clusters and Minikube for local experiments. Kubernetes unlocks powerful automation for containerized apps, and with this guide, you’re equipped to deploy, manage, and troubleshoot with confidence.


FAQs

How do I uninstall Kubernetes from Ubuntu?

sudo kubeadm reset 
sudo apt purge kubelet kubeadm kubectl
sudo rm -rf ~/.kube 

Can I use containerd instead of Docker?

Yes! Configure containerd as the runtime during kubeadm init with –cri-socket=unix:///run/containerd/containerd.sock.

How to upgrade Kubernetes?

sudo apt update 
sudo apt install --only-upgrade kubeadm kubelet kubectl 
sudo kubeadm upgrade plan 

How do I fix “kubectl connection refused”?

sudo swapoff -a 
sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab 

Ensure the Kubernetes API server is running:

sudo systemctl restart kubelet 

How to access services in Minikube?

Use minikube service <service-name> to get a URL.

Q6: What’s the default Kubernetes network CIDR?

kubeadm uses 10.244.0.0/16 for Flannel. Adjust with –pod-network-cidr during initialization.

Share Article:

© 2025 Created by ArtisansTech