Select an IP and an FQDN for Rancher UI and create and entry on your local DNS
rancher.example.com | 10.10.10.159 |
Load Balancer
Use the ACME plugin in pfsense to request and add a certificate for rancher.
Then we go to our pfsense and configure one more Virtual IP like we did in part 3
data:image/s3,"s3://crabby-images/876b3/876b3a57dfe873fa63642904c7587e45fbe84849" alt=""
Click on Apply changes and create two firewall rules that allow ports 80 and 443 to access the ip address of the load balancer
data:image/s3,"s3://crabby-images/c365e/c365ef2101b7e66b92750fb2ed4ab51787508ecc" alt=""
Then we navigate to HAProxy, Backend and create a new Backend server pool with the three master node IPs for ports 80 and 443
- Load Balancing option Round Robin.
- Health check Basic
- Backend pass thru
- option forwardfor
- http-request set-header X-Forwarded-Host %[req.hdr(Host)]
- http-request set-header X-Forwarded-Port %[dst_port]
Backend port 80
data:image/s3,"s3://crabby-images/35966/35966c5054fcf0bf701df5b77ba929b400ade1d5" alt=""
data:image/s3,"s3://crabby-images/3564a/3564afd09bb5404fabc2d3d6e041eded555d7614" alt=""
data:image/s3,"s3://crabby-images/77ea2/77ea28511c29aa33d446792ba092865c9110343e" alt=""
Backend port 443
data:image/s3,"s3://crabby-images/aabf3/aabf3e053c355c7994261cbf976c66f15a706e74" alt=""
data:image/s3,"s3://crabby-images/99bb3/99bb315a86702089e30327f737fb024cea203b0a" alt=""
data:image/s3,"s3://crabby-images/2655e/2655e848ba0693aa9d088c5e011f7e25b64532b7" alt=""
Then create two Front Ends pointing to the respective Backends
Frontend port 80
data:image/s3,"s3://crabby-images/df66d/df66d60f4aa76efc53a9ec19864c71c237607a95" alt=""
data:image/s3,"s3://crabby-images/f8fe4/f8fe44b320652df4817112b0044d19aaf784214b" alt=""
Frontend port 443
data:image/s3,"s3://crabby-images/d2d46/d2d465479b681db3f0ebebda6e6919cb92b272bc" alt=""
data:image/s3,"s3://crabby-images/cd41d/cd41d7ca38883ab4354a682e7d46816bbe5fd151" alt=""
data:image/s3,"s3://crabby-images/5cdd4/5cdd4965ec056f526530d9f93379a2bc759d6e69" alt=""
Cert Manager
Although we are going to use pfsense for SSL termination, Cert-manager is needed in order to create self signed certificates for the Kubernetes apps including Rancher
In the previous part we added the helm repo for cert-manager called jetstack. Now we go back to our Admin node and install cert-manager. At the time of writing Rancher suggests version 1.7.1
First let’s deploy the Custom Resource Definitions
kubectl apply --validate=false -f https://github.com/cert-manager/cert-manager/releases/download/v1.7.1/cert-manager.crds.yaml
And then through Help deploy cert-manager
helm install cert-manager jetstack/cert-manager \
--namespace cert-manager \
--create-namespace \
--version v1.7.1
Rancher
Last thing before we deploy rancher is to create a namespace
kubectl create namespace cattle-system