How to Install Kubernetes Cluster (kubeadm Setup) on Ubuntu 24.04 LTS (Step-by-Step Guide)
data:image/s3,"s3://crabby-images/0bd2b/0bd2b8cbc18f4fefdef87af56d5e900503e1563f" alt=""
This document provides a step-by-step guide to setting up a Kubernetes cluster using kubeadm on multiple nodes. Kubernetes is an open-source container orchestration platform that automates the deployment, scaling, and management of containerized applications.
Kubernetes Nodes
In a Kubernetes cluster, you will encounter two distinct categories of nodes:
Master Nodes: These nodes play a crucial role in managing the control API calls for various components within the Kubernetes cluster. This includes overseeing pods, replication controllers, services, nodes, and more.
Worker Nodes: Worker nodes are responsible for providing runtime environments for containers. It’s worth noting that a group of container pods can extend across multiple worker nodes, ensuring optimal resource allocation and management.
Prerequisites
Before diving into the installation, ensure that your environment meets the following prerequisites:
- An Ubuntu 24.04 LTS system.
- Minimum 2GB RAM or more.
- Minimum 2 CPU cores (or 2 vCPUs).
- 20 GB of free disk space on /var (or more).
data:image/s3,"s3://crabby-images/97c24/97c24899718f6934f9431163ed3a7d60a9a013c5" alt=""
data:image/s3,"s3://crabby-images/68e83/68e832a587d4d69f485f583171cf49813bb69df3" alt=""
data:image/s3,"s3://crabby-images/96be0/96be0c280c86d0b4ce220b1570362b8bcb77d31f" alt=""
data:image/s3,"s3://crabby-images/6a8b4/6a8b4682fe74054a62e5a866bbefb249c46e6591" alt=""
data:image/s3,"s3://crabby-images/e949e/e949e4255b3c0f9895dbb748ffaec21255276f46" alt=""
data:image/s3,"s3://crabby-images/b603e/b603e7e277db4bbd145bb3d9b026fe183050f206" alt=""
- Ensure machines in the cluster can ping each other via IP and hostname.
data:image/s3,"s3://crabby-images/8720c/8720c791b63fdb04aaac27c93d28f2ad742d4d55" alt=""
data:image/s3,"s3://crabby-images/48721/48721f0f6c58343d4a50fefefe366720caadc29e" alt=""
data:image/s3,"s3://crabby-images/4ecaa/4ecaa1d2e75d23e5bd366fc3c8de5dbd1923f201" alt=""
hostnamectl set-hostname master-node
bash
hostname
data:image/s3,"s3://crabby-images/056c9/056c9a7b6d53ab4bd693c9559fa84f19d1fa0ff1" alt=""
hostnamectl set-hostname worker-node-1
bash
hostname
data:image/s3,"s3://crabby-images/5acc4/5acc41490f851aeb996ec9e4b507ecc4002597c6" alt=""
hostnamectl set-hostname worker-node-2
bash
hostname
data:image/s3,"s3://crabby-images/4f4cb/4f4cb8ef393e65bb49af38a540fc9d9b82e603cf" alt=""
- Edit the
/etc/hosts
file to include mappings of IP addresses to hostnames.
$ vi /etc/hosts
172.31.0.196 master-node
172.31.0.233 worker-node-1
172.31.0.123 worker-node-2
data:image/s3,"s3://crabby-images/78231/78231470672b87cdf49d55da07e7f403ae6e1c07" alt=""
data:image/s3,"s3://crabby-images/04e3c/04e3c1e6ada3a5f5a39cdb8d602d612108abb79e" alt=""
data:image/s3,"s3://crabby-images/88b7a/88b7a99122afc7dc8ff4f3ff44b8777c0f6a0360" alt=""
ping each other via hostname:
data:image/s3,"s3://crabby-images/63667/63667d8f929da253ec5503ee6e8b1f5e7039f708" alt=""
data:image/s3,"s3://crabby-images/d109c/d109c7f615d9aa488d2a4e17bcf06379b32695a8" alt=""
data:image/s3,"s3://crabby-images/9da23/9da236b68121b63abc563f0749c296670ebcec43" alt=""
2. Disable swap on all nodes.
- Check swap status using
free -h
and disable if necessary.
3. Open required ports in the firewall.
- Check firewall status using
systemctl status firewalld
.
data:image/s3,"s3://crabby-images/0e661/0e661f4ccf9844fc45414a95bf837cafaa377737" alt=""
data:image/s3,"s3://crabby-images/a86ca/a86caed34b41712d591f3d83379d3e53d6ca247f" alt=""
data:image/s3,"s3://crabby-images/eebf6/eebf63bb2dccd027db46cb9b0b2ff6c1ab7c8e06" alt=""
4. Verify minimum hardware configuration based on official documentation.
Installing kubeadm
Follow the below steps to install kubeadm and related dependencies on all nodes.
Master Node and Worker Nodes:
- SSH into the master node.
- Ensure sudo access is available.
sudo -l
data:image/s3,"s3://crabby-images/953c3/953c32bdd9ed2c9c32743afaa5c7f8e123e1dc7e" alt=""
data:image/s3,"s3://crabby-images/cb531/cb531bbf4e780b8efeb6b6a1d7ba0aca29bc7d82" alt=""
data:image/s3,"s3://crabby-images/3d4d5/3d4d5913298145b24d843c64e86dca5cfd39cbc9" alt=""
Update packages and their versions.
sudo apt-get update && sudo apt-get upgrade -y
data:image/s3,"s3://crabby-images/8d8f0/8d8f0b430ea367a6cc5ca5293eee44cf63789788" alt=""
data:image/s3,"s3://crabby-images/bd739/bd7392561158a49a5113e5b22da261c94d4b3a8d" alt=""
data:image/s3,"s3://crabby-images/e80de/e80de327b2077ab7063de59d4773a0f863508914" alt=""
Install necessary packages: apt-transport-https
, curl
.
sudo apt-get update && sudo apt-get install -y apt-transport-https curl
data:image/s3,"s3://crabby-images/7228e/7228ea1c83120a11fb3782f402103bb1598fdfc7" alt=""
data:image/s3,"s3://crabby-images/a53d0/a53d0d30abe2a02a6bf2776f67aea1b05a5fab70" alt=""
data:image/s3,"s3://crabby-images/39616/39616f32f9e75e8bfeccbde14cdda9debaf94534" alt=""
Install Docker.
sudo apt-get install docker.io -y
data:image/s3,"s3://crabby-images/8125f/8125f0e128799e630124b1208d60f7fb7d7b03f8" alt=""
data:image/s3,"s3://crabby-images/ee303/ee3030b1f3d7f1d91a9aae3b78b373f21deed163" alt=""
data:image/s3,"s3://crabby-images/efb92/efb92aa6aef864ca53d5a5731480950a8091a069" alt=""
Add Google’s apt key to verify releases.
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
data:image/s3,"s3://crabby-images/a788d/a788d7f4af186816b4bd2946fcf2cfcc09d78c8c" alt=""
data:image/s3,"s3://crabby-images/3c626/3c6265eb1c338600b1195d70f62cf70d5113335b" alt=""
data:image/s3,"s3://crabby-images/7d8be/7d8bed204ac2942cabd4c260e0eac6596b2013ca" alt=""
sudo apt-get install -y apt-transport-https ca-certificates curl gpg
curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.30/deb/Release.key | sudo gpg - dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg
data:image/s3,"s3://crabby-images/48bfc/48bfc8b4a7640aff079f33ec46ef29aa703b46a9" alt=""
data:image/s3,"s3://crabby-images/ade17/ade17f711c03723e8b7019df3301f4791a627435" alt=""
data:image/s3,"s3://crabby-images/2d1a7/2d1a751b96d185a333d2c9f6fdc7a01cdf8c25f0" alt=""
apt-get install gpg
data:image/s3,"s3://crabby-images/340f9/340f90deb16e632f8e538e1aff04f91c3b5ec54c" alt=""
data:image/s3,"s3://crabby-images/0a28c/0a28ca40bf3bfae47e02380a9bc9100a7b92b42a" alt=""
data:image/s3,"s3://crabby-images/5a67b/5a67b847cdafc303a5d5ae59e8cd082f10b988b3" alt=""
sudo mkdir -p -m 755 /etc/apt/keyrings
curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.30/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg
Add Kubernetes apt repository.
# This overwrites any existing configuration in /etc/apt/sources.list.d/kubernetes.list
echo 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.30/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.list
# add kubernetes apt repo:
cat <<EOF | sudo tee /etc/apt/sources.list.d/kubernetes.list
deb https://apt.kubernetes.io/ kubernetes-xenial main
EOF
data:image/s3,"s3://crabby-images/ab62f/ab62f3d6aca12b6d93ed3834119c1484c33169d5" alt=""
data:image/s3,"s3://crabby-images/29731/2973106651402aeda7cd1ff3c102c6b21378015b" alt=""
data:image/s3,"s3://crabby-images/57915/5791548d07de53910be7d445e38c611c9b1f1f3a" alt=""
Update apt package index and install kubelet, kubeadm, and kubectl.
sudo apt-get update
sudo apt-get install -y kubelet kubeadm kubectl
data:image/s3,"s3://crabby-images/c0649/c0649e3ed298bb3dff8ee943867411b438d9b96e" alt=""
data:image/s3,"s3://crabby-images/2c7bd/2c7bd70cade96fe871a9141395eb8a1f7be8fe4e" alt=""
data:image/s3,"s3://crabby-images/8fdab/8fdab73650e11e2d85ac58551a6a6cb4b7ba5fd1" alt=""
Prevent automatic updates/removals of Kubernetes packages.
sudo apt-mark hold kubelet kubeadm kubectl
data:image/s3,"s3://crabby-images/74728/747282a9e4a4ec6e3d8f40aa90a955262a62d93a" alt=""
data:image/s3,"s3://crabby-images/1c245/1c245516b772f6d84a81197024f8215ef0c06452" alt=""
data:image/s3,"s3://crabby-images/69272/69272b1ec33bc2cee61fe2409b35d38156f801f2" alt=""
Initializing the Kubernetes Cluster
After installing kubeadm, initialize the Kubernetes cluster on the master node using the following steps:
- SSH into the master node.
- Run kubeadm init command with desired pod network CIDR.
kubeadm init --pod-network-cidr=172.31.0.196/16 -v=9
data:image/s3,"s3://crabby-images/611e0/611e0030367cf639f2e3545a5a4c5647234020c2" alt=""
data:image/s3,"s3://crabby-images/d235f/d235f787fc01a4e7ba8a4caa7d40f1a35f0ad54d" alt=""
Follow the instructions provided after kubeadm init completes, including setting up kubeconfig.
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config
export KUBECONFIG=/etc/kubernetes/admin.conf
Adding Worker Nodes
Join worker nodes to the master node using the provided join command:
data:image/s3,"s3://crabby-images/a8d94/a8d94dc10baf9ded3e3d4b0cfae0f7e3cde1c92e" alt=""
data:image/s3,"s3://crabby-images/a6988/a6988ff3dfddf83ab926713a8c1563b73e9f6478" alt=""
Verifying Cluster Setup
After joining all nodes to the cluster, verify the cluster status using the following command:
kubectl get nodes
# NotReady state to Ready state:
kubectl get pods -n kube-system
Ensure all nodes are in the “Ready” state.
data:image/s3,"s3://crabby-images/2aa97/2aa9730d8b1dcdfb09db4e2b936652f198172708" alt=""
Check the joined nodes:
kubectl get nodes -o wide
data:image/s3,"s3://crabby-images/7810b/7810b9d70b906585ee3a5df995692ffb5df31275" alt=""
Installing CNI Plugin (e.g., Flannel)
If necessary, install a Container Network Interface (CNI) plugin to enable networking between pods. For example, to install Flannel:
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
Conclusion
Congratulations! You have successfully set up a Kubernetes cluster using kubeadm on multiple nodes. You can now deploy and manage containerized applications on your Kubernetes cluster.
=========================
kubernet error install
==========================================================
https://hostnextra.com/learn/tutorials/how-to-install-kubernetes-k8s-on-ubuntu
Step 3: Install Kubernetes Components
Install the Kubernetes components:
kubeadm, kubelet, and kubectl
on all nodes.Add the Kubernetes apt repository:
echo "deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.30/deb/ /" | sudo tee /etc/apt/sources.list.d/kubernetes.list
curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.30/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpgNote: Replace v1.30 with latest version. Check the official release page.
Install the Kubernetes components:
sudo apt update
sudo apt install -y kubelet kubeadm kubectlHold the packages at their current version to prevent automatic upgrades:
sudo apt-mark hold kubelet kubeadm kubectl
Tidak ada komentar:
Posting Komentar