Layer 4 (LVS)
LB Layer4 reference
This page applies to:
- HAProxy ALOHA - all versions
Use the LB Layer4 tab to specify director
definitions for the Linux Virtual Server (LVS) service. The layer 4 load balancer is the IPVS component of the Linux Virtual Server (LVS) project.
Info
You cannot bind an LVS load balancer to a range of IP addresses or ports. For this capability, create a flow using the Flows tab and use the director
flow policy to direct traffic from the desired addresses and ports to the LVS load balancer.
Configuration file syntax Jump to heading
The file consists of a list of director
sections.
text
director <name> [ <ip>[:<port>] [TCP|UDP] ]balance { roundrobin | leastconn [localitybased [replication]] | source |srcdst | dest | shortestexpected | neverqueue }mode { gateway | nat | tunnel }check { [timeout <seconds>] [interval <seconds>] [source <ip>] [port <port>] }option { persistence [timeout <seconds>] [netmask <netmask>] |httpcheck [uri <uri>] [statuscode <int>] [vhost <string>] |tcpcheck | arpcheck [iface <name>] | icmpcheck }server <name> <ip>[:<port>] [weight <int>] [check] [sorry][server]...
text
director <name> [ <ip>[:<port>] [TCP|UDP] ]balance { roundrobin | leastconn [localitybased [replication]] | source |srcdst | dest | shortestexpected | neverqueue }mode { gateway | nat | tunnel }check { [timeout <seconds>] [interval <seconds>] [source <ip>] [port <port>] }option { persistence [timeout <seconds>] [netmask <netmask>] |httpcheck [uri <uri>] [statuscode <int>] [vhost <string>] |tcpcheck | arpcheck [iface <name>] | icmpcheck }server <name> <ip>[:<port>] [weight <int>] [check] [sorry][server]...
The terms are as follows.
director Jump to heading
-
director
Specifies a unique identifier for the director, the IP and port for incoming traffic, and the protocol.
balance Jump to heading
-
balance
Load balancing algorithm, one of:
Algorithm Description dest
Assigns jobs to servers through looking up a statically assigned hash table by their destination IP addresses. weightedfailover
Available since version 16.0. Weighted failover. Assigns jobs based solely on highest weight value and server availability. leastconn
Assigns more jobs to servers with fewer jobs and relative to the real servers’ weight (Ci/Wi). This is the default. leastconn localitybased
Assigns jobs destined for the same IP address to the same server if the server is available and not overloaded. Otherwise, assign jobs to servers with fewer jobs, and keep it for future assignment. leastconn localitybased replication
Assigns jobs destined for the same IP address to the least-connection node in the server set for the IP address. If all nodes in the server set are overloaded, it picks up a node with fewer jobs in the cluster and adds it in the sever set for the target. If the server set has not been modified for the specified time, the most heavily loaded node is removed from the server set, in order to avoid excessive replication. maglevhash
Available since version 16.0. Maglev hashing. Assigns jobs using consistent hashing but with minimal disruption. Each destination receives an almost equal number of connections. neverqueue
Assigns an incoming job to an idle server if one exists, instead of waiting for a fast one. If all servers are busy, it adopts the Shortest Expected Delay policy to assign the job. weightedoverflow
Available since version 16.0. Overflow connections. Assigns jobs according to a number of active connections. It maintains all connections to the node with the highest weight and overflows to the next node if the number of connections exceeds the node’s weight. Note that this scheduler might not be suitable for UDP because it only uses active connections. roundrobin
Distributes jobs equally among the available servers. Jobs are assigned to servers in proportion their weight. Servers with higher weights receive new jobs first and get more jobs than servers with lower weights. Servers with equal weights get an equal distribution of new jobs. shortexpdelay
Assigns an incoming job to the server with the shortest expected delay. The expected delay that the job will experience is (Ci + 1) / Ui if sent to the ith server, in which Ci is the number of jobs on the the ith server and Ui is the fixed service rate (weight) of the ith server. source
Assigns jobs to servers through looking up a statically assigned hash table by their source IP addresses. srcdst
Assigns jobs to servers through looking up a statically assigned hash table by their source and destination IP addresses. twoschoice
Available since version 16.0. Weighted random twos choice. Assigns jobs by selecting two random servers based on weights and then selecting the server with the fewest connections normalized by weight.
mode Jump to heading
-
mode
One of:
Mode Description gateway
Use direct routing. nat
Use destination masquerading (network access translation, or NAT). tunnel
Use ipip encapsulation (tunneling).
check Jump to heading
-
check
Specify global check parameters. If no advanced check mode is defined using these options, icmp checks are performed. Any of:
Option Description timeout <seconds>
Duration in seconds. If no connection established, check failed. The default is half of check interval. interval <seconds>
Interval between checks in seconds. The default is 10 seconds. source <ip>
Force source IP to use. port <port>
Force port destination. (Only on tcpcheck and httpcheck. By default and if it exists, the real-server port is used). rise <count>
A server will be considered as operational after consecutive successful health checks. The default is 1. fall <count>
A server will be considered as dead after consecutive unsuccessful health checks. The default is 1. inhibit
If a server is down, its weight is passed to 0 but not deleted. Established connection are not broken but new connections are dispatched on the other servers.
option persistence Jump to heading
-
option persistence
Specify that a virtual service is persistent. If this option is specified, multiple requests from a client are redirected to the same real server selected for the first request. This option may be used in conjunction with protocols such as SSL or FTP where it is important that clients consistently connect with the same real server. Any of:
Option Description timeout <seconds>
The timeout of persistent sessions may be specified, given in seconds. netmask <netmask>
Specify the granularity with which clients are grouped for persistent virtual services, as a net mask. The source address of the request is masked with this netmask to direct all clients from a network to the same real server. The default is 255.255.255.255, that is, the persistence granularity is per client host. Less specific netmasks may be used to resolve problems with non-persistent cache clusters on the client side.
option httpcheck Jump to heading
-
option httpcheck
Testing method. Checks performing an HTTP GET request on real server IP. Any of:
Option Description uri <uri>
Requested uri. (default is root /
).statuscode <int>
Expected status code. (default is 200). vhost <string>
String to set in Host header field.
option tcpcheck Jump to heading
-
option tcpcheck
Testing method. Checks opening a TCP connection on real server IP.
option arpcheck Jump to heading
-
option arpcheck
Testing method. Checks sending an arp-whoas to real server IP. Any of:
Option Description iface <name>
Network interface name.
option icmpcheck Jump to heading
-
option icmpcheck
Testing method. Checks sending an icmp echo request to real server ip.
option onepacket Jump to heading
-
option onepacket
One-packet scheduling. This option can be used only for UDP. This option is useful for scheduling UDP packets from same client port to different real servers.
server Jump to heading
-
server
Specify parameters for backend servers.
Parameter Description name
Unique identifier for the server. IP[:port]
IP address and optional port of server. If port is omitted, it defaults to destination port specified in incoming packet. weight <int>
Optional. Numeric weight of the server. check
Optional. Activate checks on the server. Check options are same as for director
, above.sorry
Optional. Classify this server as a sorry
server. It is used if all other servers are unavailable.
Important
To save a new LVS load balancer or changes to an existing load balancer, save the HAProxy ALOHA configuration. Click on the Setup tab. In the Configuration section, click Save.
LVS manager invocation options Jump to heading
Invocation options for the lvs
service are configured on the Services tab.
Do you have any suggestions on how we can improve the content of this page?