Kubernetes Control Plane Load Balancer

24 May 2020

In a cloud environment you’d typically have a proper load balancer in front of your Kubernetes cluster, such as Amazon ELB. In a bare-metal environment you don’t have this luxury, but setting up your own is rather easy.

The necessity for this is to reach the Kubernetes API on one common address, regardless of the health of your cluster. Should one node be down you’d still reach the cluster just fine, creating a proper high-availability configuration.

Setup

This setup is done on a fresh Fedora 32 VM, with access to the following Kubernetes cluster with the API running on port 6443 (default):

Name IP
kube01 10.0.0.11
kube02 10.0.0.12
kube03 10.0.0.13

Install HAProxy:

dnf install -y haproxy

Make sure HAProxy can bind to any address and port:

setsebool -P haproxy_connect_any 1

Configure HAProxy to round-robin to these hosts, with health checks:

cat <<EOF >/etc/haproxy/haproxy.cfg
frontend kubernetes-api
	mode tcp
	bind *:6443
	default_backend kubernetes-control-plane

backend kubernetes-control-plane
	mode    tcp
	balance roundrobin
	server  kube01 10.0.0.11:6443 check
	server  kube02 10.0.0.12:6443 check
	server  kube03 10.0.0.13:6443 check
EOF

Open up the port in the firewall:

firewall-cmd --add-port=6443/tcp --permanent
firewall-cmd --reload

Then enable the HAProxy service:

systemctl enable --now haproxy

And that’s it, you’re now load balancing the Kubernetes control plane.


Please enable JavaScript to view the comments powered by GitHub.