pfsense is a free network firewall software with capabilities envied by its commercial counterparts. The load balancing mechanism is provided by a plugin called HAProxy
In this configuration we have deployed two pfsense VMs, one on ESXi1 and one on ESXi2 and configured them in HA.
On a previous part we made a note of the load balancer IP which was xxx.yyy.zzz.160. We set this is up as a Virtual IP on the Master pfsense.
data:image/s3,"s3://crabby-images/23823/2382332cc3378385075751728411b3c13c515e72" alt=""
In this case, we setup the VIP as CARP. If you have a single pfSense then you select IP Alias, the Interface that connects to your recently deployed soon to be K3s nodes VMs, the address, subnet mask and Save.
Then we configure a firewall rule to allow connections to this IP on port 6443.
data:image/s3,"s3://crabby-images/01d95/01d952e7a23783f7c28ff221ff6655f9b53c15b6" alt=""
Then we navigate to HAProxy, Backend and create a new Backend server pool with the three node IPs and port 6443 and Load Balancing option Round Robin. No encryption!
data:image/s3,"s3://crabby-images/bee2e/bee2e165047a670318e80e7665382718f71b0008" alt=""
Further down under Health checking select Basic and 5000ms for Check frequency
data:image/s3,"s3://crabby-images/0b4e1/0b4e12fc94bf235870b278a1d51f9d90db3139ff" alt=""
Save and Apply the configuration.
Switch to Frontend and Create a new one following the screenshots bellow. The highlighted parts are the ones you need to fill in or select.
data:image/s3,"s3://crabby-images/01238/012384236a5ca7790ae185a2db4f0810d5b4ce95" alt=""
data:image/s3,"s3://crabby-images/29259/292597b97612813b9e1ef2821c710a84e6fbbf15" alt=""
Save and Apply the changes.