The following steps describe how to set up a proper load balancer on pfSense for Exchange 2019, 2016 or 2013 using HAProxy.
1. Before You Begin
The outlook.alwayshotcafe.com A record is added to the alwayshotcafe.com domain zone file. IP is 10.0.1.250 as seen in the screenshot.
data:image/s3,"s3://crabby-images/d82a4/d82a4114233b66a22373f5945015a50b5598b6d4" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
2. The Planned Setup
When we are done, all clients will connect to our load balancer. The balancer will forward client traffic to one of the configured CAS servers. We use round robin load balancing but you can use any other method you prefer, as the client connections are stateless we have a great amount of flexibility in that sense.
data:image/s3,"s3://crabby-images/554d2/554d2fc8b1b885e7dcf7d6d3a731b69f1e548821" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
3. Install HAProxy on pfSense
Under System, select Package Manager/Available Packages and search for "haproxy". Click on the Install button.
data:image/s3,"s3://crabby-images/6648a/6648a4e52ac51cc47c122bba791a7bc5be1e956b" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
4. Configure HAProxy
After installing it open the configurator under the Services tab. a. Under Settings enable the service, set max connection number to 1000.
data:image/s3,"s3://crabby-images/f03e8/f03e8096d62b175d31299011bbf9629fbe06e991" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
b. Set the internal stats port to 2200 so the stat page can be accessed later
data:image/s3,"s3://crabby-images/55d47/55d475bdc1945666a5ea9de6b6eb0951835100a4" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
c. SSL DH size needs to be at least 2048
data:image/s3,"s3://crabby-images/6dfed/6dfed3deb06e9ca20c9c2d53da23e931bf185a8a" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
d. Under the Backend tab we specify the name of the backend server collection, which is outlook_servers for easy identification. Then we add our three mailbox servers to the list, specifying port 443 with SSL encryption on.
data:image/s3,"s3://crabby-images/2cf8d/2cf8dfe40f56340f5b3b545ccb884e9373045306" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
e. Load balancing is set to round-robin, but you can set any option you prefer.
data:image/s3,"s3://crabby-images/3fadc/3fadce359dd449a5d6b39045fcac7ad766164973" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
f. Health checking is 'none' in our case, as we have a lab it doesn't need to check if the connection to the backend servers are up. If one goes down, we adjust the load balancer manually.
data:image/s3,"s3://crabby-images/813cc/813cc9102b670530afde781346d0981c92bc48a9" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
g. Make connections sticky, so clients will not jump from one backend server to another making their user experience more seamless. Outlook can hang briefly when jumping CAS servers.
data:image/s3,"s3://crabby-images/a7935/a79353b75dcfe930e47d7dc985cede6b3af24462" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
h. Set up the 10.0.1.250 virtual IP address earlier under the Firewall tab for the "outlook" listener
data:image/s3,"s3://crabby-images/04c89/04c89b161e72ef7962d530296bf472173074ce47" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
i. For SSL offloading to work (see next step), we need to import the SSL certificate for outlook.alwayshotcafe.com, that same that we use on the mailbox servers. In this example we use a wildcard cert which covers all hosts in the alwayshotcafe.com domain. For detailed steps on how to export the SSL certificate from an Exchange server and extract the private-, public keys and CA certificate from the PFX file, see the guide here.
Import the ca.cer to CAs
data:image/s3,"s3://crabby-images/f9c24/f9c240d421aa28322ca6dc93feb8232bbc2d051f" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
Then import pub.cer and priv.cer in the certificate store.
data:image/s3,"s3://crabby-images/57d82/57d825928459923d4babcee2dbfffa38dc453954" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
j. Under the Frontend tab we can set up the listener on the pfSense firewall. We use the virtual IP from step h., with port 443 listening. SSL offloading is also enabled. That means the client connection has the endpoint on the firewall, so the load balancer can see connection details, like session information for proper L7 balancing. This would be inaccessible if the encrypted HTTPS connection just passed through the load balancer.
data:image/s3,"s3://crabby-images/32b05/32b05e9c62d108ee7533a4f417185cf21fdbfc84" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
k. Create an access list called "outlook", with incoming https requests to match outlook.alwyashotcafe.com. Action is set to use the "outlook_servers" backend collection
data:image/s3,"s3://crabby-images/1f12c/1f12c73cf6e1c05320578f7e0d88bfbee4fdbf9a" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
l. The forwardfor option is checked
data:image/s3,"s3://crabby-images/94deb/94deb47d6203047b91a004afa2f7c41b9c38ca21" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
m. Under the SSL Offloading section select the wildcard certificate we imported in step i.
Hello! This is the Gutenberg block you can edit directly from the WPBakery Page Builder.
n. The last step is very important: to allow connection on this address, under the firewall section we allow HTTPS traffic from all sources on all interfaces to the "outlook_servers" alias.
First, create alias for the three mailbox servers
data:image/s3,"s3://crabby-images/f9893/f9893dd7bc834c5cc48bc52ae6d56745c7041810" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
Now you can add a floating firewall rule that is flexible as it applies to all interfaces
data:image/s3,"s3://crabby-images/59e86/59e864e5023c8596529f05f1843b518922aec71e" alt="Load Balancer for Exchange 2019, 2016 and 2013 with HAProxy | FREE"
Hi, thanks for this tutorial, very helpfull.
But I have a question regarding the firewall rule to allow access to the backend servers, I think this shouldn’t happen because we proxy all traffic via the VIP interface! so I think you have to allow only https traffic to the VIP interface only not the backend servers.
Thanks.