I can provide you with a step-by-step guide on how to set up a Rancher RKE2 HA cluster using Nginx as the load balancer. Here are the steps:
Prerequisites:
- Three or more Ubuntu 20.04 servers with 2 CPUs, 4GB of RAM, and 30GB of storage each
- Root access to all servers
- An SSH key pair for authentication
- A domain name pointing to the IP address of the load balancer
Step 1: Install and configure Nginx
- Log in to the server that will be used as the load balancer.
- Install Nginx using the following command:
sudo apt-get install nginx
- Once Nginx is installed, stop the service using the following command:
sudo systemctl stop nginx
- Open the Nginx configuration file
/etc/nginx/nginx.conf
using your favorite text editor. - Add the following content to the end of the
http
block to configure the load balancer:
cssCopy codeupstream rke2_servers {
server <IP_ADDRESS_OF_SERVER_1>:6443;
server <IP_ADDRESS_OF_SERVER_2>:6443;
server <IP_ADDRESS_OF_SERVER_3>:6443;
}
server {
listen 80;
server_name <YOUR_DOMAIN_NAME>;
location / {
proxy_pass https://rke2_servers;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
- Save and close the configuration file.
- Start the Nginx service using the following command:
sudo systemctl start nginx
Step 2: Install RKE2 on all servers
- Log in to all servers as the root user.
- Download the RKE2 binary using the following command:
curl -sfL https://get.rke2.io | sh -s -- --version v1.21.4+rke2r1
- Once the binary is downloaded, install RKE2 using the following command:
sudo installer -o root -g root -m 0755 -n /usr/local/bin/rke2 /tmp/rke2*/rke2
- Initialize RKE2 using the following command:
sudo rke2 server --cluster-init
- Once the initialization is complete, copy the
kubeconfig.yaml
file to your local machine using the following command:sudo cat /etc/rancher/rke2/rke2.yaml > kubeconfig.yaml
- Repeat steps 2-5 for all servers in the cluster.
Step 3: Configure the Kubernetes API server
- Open the
kubeconfig.yaml
file using your favorite text editor. - Find the
server
entry and replace the IP address with the domain name of the load balancer. - Save and close the file.
Step 4: Join the cluster
- Log in to each server as the root user.
- Run the following command to join the cluster:
sudo rke2 server --server https://<YOUR_DOMAIN_NAME>:6443 --token <CLUSTER_TOKEN>
- Repeat step 2 for all servers in the cluster.
Step 5: Verify the cluster
- Log in to any server as the root user.
- Verify the status of the cluster using the following command:
sudo kubectl get nodes
- If all nodes are in the
Ready
state, the cluster is successfully set up.
That’s it! You have successfully set up a Rancher RKE2 HA cluster using Nginx as the load balancer.
I’m a DevOps/SRE/DevSecOps/Cloud Expert passionate about sharing knowledge and experiences. I am working at Cotocus. I blog tech insights at DevOps School, travel stories at Holiday Landmark, stock market tips at Stocks Mantra, health and fitness guidance at My Medic Plus, product reviews at I reviewed , and SEO strategies at Wizbrand.
Please find my social handles as below;
Rajesh Kumar Personal Website
Rajesh Kumar at YOUTUBE
Rajesh Kumar at INSTAGRAM
Rajesh Kumar at X
Rajesh Kumar at FACEBOOK
Rajesh Kumar at LINKEDIN
Rajesh Kumar at PINTEREST
Rajesh Kumar at QUORA
Rajesh Kumar at WIZBRAND