Using Kubeadm for Kubernetes Cluster Initialization
Kubeadm is one of the most popular tools for setting up and initializing a Kubernetes cluster. It simplifies the process of creating a Kubernetes cluster by providing a set of commands for both master node and worker node initialization, as well as tools for managing the lifecycle of the cluster. Kubeadm is best suited for users who want to create a production-ready Kubernetes cluster and have some control over the components and configurations.
In this guide, we’ll walk through how to use Kubeadm to initialize a Kubernetes cluster and set up the essential components for a functional environment.
What is Kubeadm?
Kubeadm is a command-line tool provided by Kubernetes for the cluster initialization process. It automates the most important steps involved in setting up a Kubernetes cluster, such as:
- Initializing the control plane (Master Node)
- Installing and configuring kubelet and kube-proxy
- Joining worker nodes to the cluster
- Handling the cluster networking setup
- Generating the necessary certificates and configuration files
Kubeadm does not install a full Kubernetes setup on its own (i.e., it does not provide high-level orchestration, networking, or dashboards). Instead, it is designed to initialize the base of the Kubernetes infrastructure, leaving the customization (such as networking, ingress, and monitoring) up to the user.
Prerequisites for Using Kubeadm
Before using Kubeadm to initialize your Kubernetes cluster, ensure that the following requirements are met:
- Operating System: Ubuntu, CentOS, or other Linux distributions (with a supported kernel version).
-
Hardware Requirements:
- At least 2 GB of RAM for the master node.
- At least 1 CPU (for both the master and worker nodes).
-
Dependencies:
- Docker (or another container runtime) installed on all nodes.
- Kubeadm, Kubelet, and Kubectl installed on all nodes.
- Ensure that swap is disabled on all nodes. You can disable swap with:
sudo swapoff -a
And to make it permanent:
sudo sed -i '/ swap / s/^/#/' /etc/fstab
-
Networking: You will need to set up a networking solution (e.g., Flannel, Calico) to allow Pods across nodes to communicate.
Step-by-Step Guide to Initialize Kubernetes Using Kubeadm
1. Install Docker and Kubeadm Packages
First, ensure that Docker and Kubernetes components (kubeadm
, kubelet
, and kubectl
) are installed on all nodes.
Install Docker:
sudo apt-get update
sudo apt-get install -y docker.io
Install Kubeadm, Kubelet, and Kubectl:
sudo apt-get update && sudo apt-get install -y apt-transport-https
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee -a /etc/apt/sources.list.d/kubernetes.list
sudo apt-get update
sudo apt-get install -y kubeadm kubelet kubectl
Verify the installation:
kubectl version --client
kubeadm version
2. Disable Swap on All Nodes
Ensure that swap is disabled on both the master and worker nodes (this is a Kubernetes requirement).
sudo swapoff -a
To disable swap permanently, modify the /etc/fstab
file:
sudo sed -i '/ swap / s/^/#/' /etc/fstab
3. Initialize the Kubernetes Master Node
On the master node, initialize the Kubernetes cluster using the kubeadm init
command:
sudo kubeadm init --pod-network-cidr=10.244.0.0/16
- The
--pod-network-cidr
flag defines the CIDR block for Pod networking (this is necessary for certain network plugins like Flannel). If you’re using a different network plugin, refer to its specific documentation for the appropriate CIDR. - The output will include a token that can be used to join worker nodes to the cluster, along with a
kubeadm join
command. Save this command for use on the worker nodes.
Example output:
kubeadm join <master-ip>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>
After initializing the master node, follow the steps below to set up kubectl and configure the cluster.
4. Set Up kubectl for Master Node Access
Run the following commands to configure kubectl
on the master node so that you can interact with the cluster:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
Now verify the cluster status with kubectl
:
kubectl get nodes
You should see the master node listed as NotReady
because there is no network plugin installed yet.
5. Install a Network Plugin
Before worker nodes can be joined, you must set up a network plugin. For this example, we’ll use Flannel, but other plugins like Calico or Weave Net can also be used.
To install Flannel:
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
After applying the network plugin, check the status of the pods:
kubectl get pods --all-namespaces
Ensure that the kube-flannel-ds
pod is running in the kube-system
namespace.
6. Join Worker Nodes to the Cluster
Now that the master node is initialized, you can join worker nodes using the kubeadm join
command that was generated during the master node initialization.
On each worker node, run the command (replace the token and hash with the output from kubeadm init
):
sudo kubeadm join <master-ip>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>
After the worker nodes join, verify the nodes in the cluster:
kubectl get nodes
You should see both the master and worker nodes listed as Ready
.
7. (Optional) Install a Kubernetes Dashboard
To manage your Kubernetes cluster via a web UI, you can install the Kubernetes Dashboard.
Run the following command to install it:
kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.0-beta8/aio/deploy/recommended.yaml
Then create an admin user to access the dashboard:
kubectl apply -f dashboard-adminuser.yaml
To access the dashboard, create a proxy:
kubectl proxy
Then access the dashboard via:
http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/
Conclusion
Using Kubeadm to initialize a Kubernetes cluster is an excellent choice for users who want control over the Kubernetes setup process. By following the steps outlined above, you can successfully set up a Kubernetes cluster with a master node, worker nodes, and a network plugin like Flannel for communication. Kubeadm helps automate many of the tedious aspects of cluster initialization, but it also gives you the flexibility to customize your environment and integrate different solutions.
Key Takeaways:
- Kubeadm is used for initializing and managing Kubernetes clusters, including node joining and networking setup.
- You need to set up a network plugin (like Flannel or Calico) to enable pod communication across nodes.
- Disable swap and ensure that Kubernetes dependencies like
kubeadm
,kubelet
, andkubectl
are installed. - After the cluster is initialized, you can scale it by adding more worker nodes.
By following these steps, you’ll have a fully operational Kubernetes cluster up and running, ready for managing your containerized applications.