Product docs and API reference are now on Akamai TechDocs.
Search product docs.
Search for “” in product docs.
Search API reference.
Search for “” in API reference.
Search Results
 results matching 
 results
No Results
Filters
Getting Started with HAProxy TCP Load Balancing and Health Checks
Traducciones al EspañolEstamos traduciendo nuestros guías y tutoriales al Español. Es posible que usted esté viendo una traducción generada automáticamente. Estamos trabajando con traductores profesionales para verificar las traducciones de nuestro sitio web. Este proyecto es un trabajo en curso.
HAProxy serves as a reverse proxy between frontend client requests and backend server resources, and can be configured at Layer 4 (network) or Layer 7 (application). A common use of HAProxy is as an intelligent network load balancer. In this role, HAProxy routes incoming frontend traffic to designated backend instances. By default, no load balancing is applied, however, HAProxy can be configured to use various load balancing methods, including:
- Round Robin: Distributes incoming connections evenly across all available backend servers by sequentially assigning each new connection to the next server in the pool.
- Least Connections: Directs incoming connections to the backend server with the fewest active connections, helping to balance the load more evenly based on current server utilization.
- Health Checks: Continuously monitors the health of backend servers. Servers that fail health checks are automatically removed from the pool until they recover, ensuring that only healthy servers receive traffic.
This guide demonstrates how to install HAProxy onto three Linux distributions: Ubuntu, CentOS Stream, and openSUSE Leap. It also uses an example WordPress deployment with sample configurations to implement and test HAProxy’s TCP load balancing and health check features.
Before You Begin
To be used as your HAProxy instance, deploy a Compute Instance running one of the
Ubuntu 24.04 LTS
,CentOS Stream 9
, oropenSUSE Leap 15.6
distributions, and assign the instance to a VLAN. See our Getting Started with Linode and Creating a Compute Instance guides.HAProxy can be deployed using a Nanode plan for testing purposes. See HAProxy’s hardware recommendations for production-level workloads.
Follow our Setting Up and Securing a Compute Instance guide to update your system. You may also wish to set the timezone, configure your hostname, create a limited user account, and harden SSH access.
This guide uses WordPress backend instances to demonstrate how HAProxy controls network traffic flows at both the TCP/Network (Layer 4) and HTTP/Application (Layer 7) levels. Follow the steps in our Deploy WordPress through the Linode Marketplace guide to create three backend WordPress test instances. Fill out all required fields under WordPress Setup, and use default values along with the following options:
- The stack you are looking to deploy Wordpress on: Choose either LAMP or LEMP.
- Website title: For each instance, enter
backend1
,backend2
, andbackend3
, respectively. - Region: Select the same location the HAProxy instance is in.
- Linode Plan: A Shared CPU, Nanode 1 GB is sufficient to test and demonstrate HAProxy options.
- Linode Label: Label each instance to correspond with the website titles
backend1
,backend2
, andbackend3
, respectively. - VLAN: Attach the instances to the same VLAN as the HAProxy instance.
Each server is generated with an
index.html
home page that indicates the given title of the website hosted on the instance (backend1
,backend2
, orbackend3
). Open a web browser and navigate to each server’s IP address to verify that the example test servers are functioning. Take note of the IP addresses of each backend instance, as they are used later.
sudo
. If you’re not familiar with the sudo
command, see the Users and Groups guide.Install HAProxy
To install HAProxy, log into the HAProxy instance as your limited sudo user, and complete the steps below.
Select your distribution, and use the command to install HAProxy:
Verify the HAProxy installation by checking the installed version number:
sudo haproxy -v
Use
systemctl
to start HAProxy:sudo systemctl start haproxy
Use
systemctl
to configure HAProxy to automatically start after a reboot:sudo systemctl enable haproxy
Verify HAProxy is
active (running)
:systemctl status haproxy
● haproxy.service - HAProxy Load Balancer Loaded: loaded (/usr/lib/systemd/system/haproxy.service; enabled; preset: enabled) Active: active (running) since Tue 2024-09-17 20:37:22 UTC; 1 day 1h ago Docs: man:haproxy(1) file:/usr/share/doc/haproxy/configuration.txt.gz Process: 46011 ExecReload=/usr/sbin/haproxy -Ws -f $CONFIG -c -q $EXTRAOPTS (code=exited, status=0/SUCCESS) Process: 46014 ExecReload=/bin/kill -USR2 $MAINPID (code=exited, status=0/SUCCESS) Main PID: 35012 (haproxy) Status: "Ready." Tasks: 2 (limit: 1068) Memory: 40.6M (peak: 75.5M swap: 224.0K swap peak: 23.9M) CPU: 37.675s CGroup: /system.slice/haproxy.service ├─35012 /usr/sbin/haproxy -Ws -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid -S /run/haproxy-master.sock └─46018 /usr/sbin/haproxy -sf 45988 -x sockpair@5 -Ws -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid -S /run/haproxy-master.sock
The HAProxy Configuration File
HAProxy is controlled through its configuration file and the CLI. The default HAProxy configuration file is created at /etc/haproxy/haproxy.cfg
during installation, and contains the settings needed to perform network balancing and flow control. It can be edited with any command line-based text editor.
To edit and use the TCP load balancing and health check functions in this guide, open the HAProxy configuration file with the text editor of your choice:
sudo nano /etc/haproxy/haproxy.cfg
TCP Load Balancing
Load balancing is defined in two sections of the HAProxy configuration file: frontend
and backend
. Below are example frontend
and backend
configurations for TCP load balancing:
Frontend Configuration
- File: /etc/haproxy/haproxy.cfg
1 2 3 4
frontend web-test bind *:80 mode tcp default_backend web-test
frontend
declares that this section is for a frontend configuration calledweb-test
.bind
specifies the interface and port that HAProxy listens to for incoming connections. Here,*:80
means that HAProxy listens on all available IP addresses (*
) on port80
, which is the standard port for web traffic.mode
is set to TCP, so that HAPRoxy handles traffic at the transport layer.default_backend
directs this traffic to a backend namedweb-test
, as defined in the next section.
Backend Configuration
- File: /etc/haproxy/haproxy.cfg
1 2 3 4 5 6
backend web-test mode tcp balance roundrobin server server1 backend1_VLAN_IP_ADDRESS:80 server server2 backend2_VLAN_IP_ADDRESS:80 server server3 backend3_VLAN_IP_ADDRESS:80
backend
declares that this section is for a backend configuration calledweb-test
.mode
is again set to TCP, telling HAPRoxy to handle traffic at the transport layer.balance
is set to the Round Robin method, which connects each client reaching the HAProxy server’s IP address to the next server in the list.server
statements define the backend servers using the VLAN addresses specified during the initial HAProxy setup.
TCP Health Checks
HAProxy’s load balancing function can also select servers based on their health status. Health checks can be either active or passive. An active health check probes each backend server individually for specific health attributes, whereas a passive check relies on basic connection error information by protocol (Layer 4/TCP or Layer7/HTTP).
To enable a basic server health check, include the check
keyword in the server
entry of your HAProxy configuration file:
- File: /etc/haproxy/haproxy.cfg
1
server server1 backend1_VLAN_IP_ADDRESS:80 check
When the check
keyword is included, HAProxy sends a SYN/ACK request to determine if a server is active. In some cases, servers may correctly respond to this type of query, while individual services and applications may still be down or unavailable.
Active TCP Health Checks
Active health checks provide more sophisticated monitoring by sending application-specific queries to backend servers and expecting a valid response in return.
To have HAProxy check server health at specified intervals, include the inter
keyword along with an interval value. For example:
- File: /etc/haproxy/haproxy.cfg
1
server server1 backend1_VLAN_IP_ADDRESS:80 check inter 4
In this example, HAProxy checks the first server in the pool every four seconds. If the server does not respond as expected, it is marked as down. This process functions like a ping-style health check to verify server availability.
Passive TCP Health Checks
HAProxy uses the TCP protocol to perform passive health checks on backend servers. With passive health checks, HAProxy monitors Layer 4 (TCP) traffic for errors and marks a server as down when a specified error limit is reached.
Below is an example of the syntax used for a passive health check:
- File: /etc/haproxy/haproxy.cfg
1
server backend1 backend1_VLAN_IP_ADDRESS:80 check observe layer4 error-limit 10 on-error mark-down
This configuration specifies a passive health check that observes TCP errors (observe layer4
). If the number of errors reaches the specified limit of 10 (error-limit 10
), the server is marked as down (on-error mark-down
). To optimize performance and reliability, you can adjust the intervals and error limits for different servers based on their capacity, role, or complexity. For more information, refer to the HAProxy documentation on active health checks.
Configure TCP Load Balancing with Health Checks
Set the HAProxy configuration file to perform TCP load balancing with basic passive health checks.
Open the HAProxy configuration file with the text editor of your choice:
sudo nano /etc/haproxy/haproxy.cfg
Append the following code to the end of the file, and save your changes:
- File: /etc/haproxy/haproxy.cfg
1 2 3 4 5 6 7 8 9 10 11
frontend web-test bind *:80 mode tcp default_backend web-test backend web-test mode tcp balance roundrobin server server1 backend1_VLAN_IP_ADDRESS:80 check server server2 backend2_VLAN_IP_ADDRESS:80 check server server3 backend3_VLAN_IP_ADDRESS:80 check
Restart HAProxy to enable the changes made to the configuration file:
sudo systemctl restart haproxy
Check for syntax errors If you encounter any errors after reloading HAProxy, run the following command to check for syntax errors in your
haproxy.cfg
file:sudo haproxy -c -f /etc/haproxy/haproxy.cfg
An error message is returned if the configuration file has logical or syntax errors. When the check is complete, each error is listed one per line.
This command only verifies the syntax and basic logic of the configuration, and it does not guarantee that the configuration works as intended when running.
Test TCP Load Balancing
Load balancing can be verified by visiting the HAProxy instances’s public IP address.
The default firewall settings for CentOS Stream 9 must be changed prior to testing. Run the following command to temporarily open port 80
to tcp
traffic:
sudo firewall-cmd --add-port=80/tcp
Alternatively, use the commands below to configure the firewall to permanently allow tcp
traffic on port 80
:
sudo firewall-cmd --permanent --add-port=80/tcp
sudo firewall-cmd --reload
Open a web browser and navigate to the HAPRoxy instance’s public IP address:
http://HAProxy_PUBIC_IP_ADDRESS
The WordPress web page for
backend1
should appear:Certificate warnings If your browser warns of no HTTPS/TLS certificate, ignore the warning or use the advanced settings to reach the site.Open another browser tab and enter the same HAProxy server IP address. This time, the default page for
backend2
should be displayed:Repeat this process in a third browser tab, and the
backend3
server’s web page should appear:
The HAProxy gateway is now successfully balancing traffic between the three backend instances using the Round Robin method.
Verify TCP Health Checks
Health checks can be verified by removing one of the backend instances from the server pool. This should trigger a health check failure, causing HAProxy to exclude the unresponsive server from the backend pool.
Open the Cloud Manager and choose Linodes
Click on the ellipsis (…) to the right of your first backend instance,
backend1
.Choose Power Off, then click Power Off Linode.
Reload the web browser tabs. HAProxy should no longer route traffic to
backend1
, effectively removing it from the pool.Return to the HAProxy instance and check the logs:
sudo tail -f /var/log/haproxy.log
Your output should contain a “WARNING” line regarding the “DOWN” status of
server1
:[WARNING] (4494) : Server web-test/server1 is DOWN, reason: Layer4 connection problem, info: "No route to host", check duration: 1ms. 2 active and 0 backup servers left. 0 sessions active, 0 requeued, 0 remaining in queue.
This shows that HAProxy’s TCP health checks are working as intended.
More Information
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
This page was originally published on