The Windows Server Routing and Remote Access Service (RRAS) is a popular choice for a VPN server to support Windows 10 Always On VPN deployments. One significant advantage RRAS provides is support for the Secure Socket Tunneling Protocol (SSTP). SSTP is a Microsoft proprietary VPN protocol that uses Transport Layer Security (TLS) to ensure privacy between the VPN client and server. The advantage to using a TLS-based transport is that it leverages the standard HTTPS TCP port 443, making it firewall friendly and ensuring ubiquitous remote access even behind highly restrictive firewalls.
Load Balancing SSTP
Load balancing SSTP can be accomplished in much the same way as a load balancing a common web server using HTTPS. The external load balancer is configured with a virtual IP address (VIP) and each VPN server is configured behind it. Session persistence should be configured to use SSL with source IP address persistence as a fallback.
SSL Offload for SSTP
In most cases, simply forwarding encrypted SSTP connections to the VPN server will be sufficient. However, offloading SSL/TLS processing to an Application Delivery Controller (ADC) or load balancer can be beneficial for the following reasons.
Resource Utilization
Enabling TLS offload for SSTP VPN connections can reduce CPU and memory utilization on the VPN server. However, this will likely only be necessary for very busy servers supporting many concurrent connections.
Security
In some cases, the administrator may not be able to install the public SSL certificate on the VPN server. For example, a security policy may exist that restricts SSL certificate installation to dedicated security devices using a Hardware Security Module (HSM). In some cases, it may be desirable to restrict access to high value certificates such as wildcard certificates.
Certificate Management
Often SSL certificates are implemented on load balancers to reduce certificate sprawl and to ease the management and administration burden in the enterprise. By having all enterprise certificates installed only on dedicated security devices, administrators can more effectively monitor and manage SSL certificate lifecycles.
SSTP Configuration for TLS Offload
Configuration changes must be made on the load balancer and the RRAS server to support TLS offload for SSTP.
Load Balancer
Install the public SSL certificate on the load balancer and configure it for TLS termination. Configure the load balancer to then use HTTP for backend server connections. Consult the load balancer vendor’s documentation for configuration guidance.
Load Balancing Always On VPN SSTP Load Balancing with F5 BIG-IP
RRAS Server
If the public SSL certificate is installed on the VPN server, enabling TLS offload for SSTP is simple and straightforward. Follow the steps below to enable TLS offload for SSTP VPN connections.
- Open the RRAS management console (rrasmgmt.msc).
- Right-click the VPN server and choose Properties.
- Select the Security tab.
- Check Use HTTP in the SSL Certificate Binding section.
- Click Ok and then Yes to restart the Remote Access service.
If the public SSL certificate is not or cannot be installed on the RRAS server, additional configuration will be required. Specifically, SSL offload for SSTP must be configured using the Enable-SSTPOffload PowerShell script, which can be downloaded here.
Once the script has been downloaded and imported, open an elevated PowerShell command window and enter the following command.
Enable-SSTPOffload -CertificateHash [SHA256 Certificate Hash of Public SSL Certificate] -Restart
For example…
Enable-SSTPOffload -CertificateHash “C3AB8FF13720E8AD9047DD39466B3C8974E592C2FA383D4A3960714CAEF0C4F2” -Restart
Re-Encryption
When offloading TLS for SSTP VPN connections, all traffic between the load balancer and the VPN server will be sent in the clear using HTTP. In some scenarios, TLS offload is required only for traffic inspection, not performance gain. When terminating TLS on the load balancer and re-encrypting connections to the VPN server is required, it is only supported if the same certificate is used on both the load balancer and the VPN server.
Additional Information
Windows 10 Always On VPN SSL Certificate Requirements for SSTP
Windows 10 Always On VPN SSL Load Balancing with F5 BIG-IP
Windows 10 Always On VPN IKEv2 and SSTP Fallback
Windows 10 Always On VPN Hands-On Training Classes for 2019
Agile IT (@Agile_IT)
/ April 9, 2019Richard, is there a way to load balance/provide high availability for Always On VPN with IKEv2…using Windows NLB?
It appears you need Kemp or an F5 to do it.
Richard M. Hicks
/ April 9, 2019No, you could use Windows NLB to provide load balancing for VPN connections. I haven’t written about it because I’m not a big fan of NLB. I much prefer load balancing with a purpose-built network device. 🙂
Justin
/ November 5, 2020Hi Richard, Thanks for another great post! I have AOVPN configured with SSTP/IKEv2. I have noticed download speed on SSTP to be half of the speed I get with IKEv2. The servers aren’t heavily utilized so I’m not sure if using a load balancer would help this or if there is something else I should be looking at?
Richard M. Hicks
/ November 6, 2020Adding a load balancer won’t help, I’m sure. I suspect perhaps an issue with network configuration somewhere, or perhaps an edge firewall. In my experience SSTP throughput is actually a tick better than IKEv2. 🙂
Justin
/ November 10, 2020Thank you, that’s good to know! I will try and figure out the blocker.