API Objects Reference
L4 farm
This page applies to:
- HAProxy ALOHA - all versions
A farm is a container for real servers. The contained servers must have the same role and deliver the same service.
Farm attributes and options define the session behavior on the server side of the load balancer, such as how to check, dispatch connections, connect, forward data, and maintain sessions to real servers.
Farms are identified by a name; allowed characters include alpha-numeric, dot, dash, and underscore.
The available farm attributes are listed below:
balance Jump to heading
-
Definition: Load balancing algorithm used to dispatch new connections on real servers.
-
Type: enum
-
Default value:
roundrobin
Value | Description |
---|---|
roundrobin |
Each server is used in turn according to their weights. |
least-connections |
The new connection is affected to the server with the lowest number of connections. |
hash-source |
The source IP address is hashed and divided by the total weight of the running servers to designate which server will receive the request. This ensures that the same client IP address will always reach the same server as long as no server goes down or up. |
hash-destination |
Assigns jobs to servers through looking up a statically assigned hash table based on destination IP addresses. |
hash-source-dest |
Assigns jobs to servers through looking up a statically assigned hash table based on both source and destination IP addresses. |
shortest-expected-delay |
Assign an incoming job to the server with the shortest expected delay. |
never-queue |
Assign an incoming job to an idle server if there is one instead of waiting for a fast one; if all the servers are busy, it adopts the Shortest Expected Delay policy to assign the job. |
mode Jump to heading
-
Definition: Deployment mode
-
Type: enum
-
Default value: Destination IP masquerading
Value | Description |
---|---|
gateway |
Direct routing or direct server return (DSR) mode |
nat |
Destination IP masquerading (Network Address Translation, or NAT) |
tunnel |
ipip encapsulation (tunneling) |
persistence Jump to heading
-
Definition: If this option is enabled, multiple requests from a client (same source IP) 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.
-
Type: enum
-
Default value: Persistence is disabled
Value | Description |
---|---|
enabled |
persistence is enabled |
persistence-timeout Jump to heading
Info
This attribute is ignored if persistence
is not set to enabled
.
-
Definition: Value in seconds specify how long sessions are kept persistence load balance table.
-
Type: integer
-
Default value: 300 seconds
persistence-netmask Jump to heading
Info
This attribute is ignored if persistence
is not set to enabled
.
-
Definition: Specify the granularity of persistence
-
Type: ip
-
Default value: 255.255.255.255
service-address Jump to heading
-
Definition: IP address on which to intercept traffic
-
Type: ip
-
Default value: no interception
service-port Jump to heading
Info
This attribute is ignored unless service-address
is configured.
-
Definition: network port to intercept traffic on
-
Type: port
-
Default value: all ports for the service-address are intercepted
-
Particular value: 0 means interception of all ports
service-protocol Jump to heading
Info
This attribute is ignored unless service-address
is configured.
-
Definition: layer 4 protocol (udp or tcp) to intercept
-
Type: enum
-
Default value: tcp is intercepted
Value | Description |
---|---|
tcp |
intercept tcp |
udp |
intercept udp |
check-interval Jump to heading
-
Definition: Interval between two consecutive server health checks in seconds
-
Type: integer
-
Default value:
10
check-port Jump to heading
-
Definition: Destination TCP port used to perform health check
-
Type: integer
-
Default value: Server port is used
check-timeout Jump to heading
-
Definition: Additional health check timeout, starts after the connection has been established on the server
-
Type: integer
-
Default value:
check-interval
/2
check-source Jump to heading
-
Definition: Source IP address to use when performing health checks
-
Type: ip
-
Default value: First load balancer interface address is used
adv-check Jump to heading
-
Definition: Advanced health check method
-
Type: enum
-
Default value:
icmp
Value | Description |
---|---|
http |
Use an http request health checks for server testing, If http status code 200 is returned, check is successful |
tcp |
Perform a tcp connect. If connect accepted, check is successful |
icmp |
process an icmp echo to server, if echo reply received, check is successful |
adv-check-http-uri Jump to heading
Info
This attribute is ignored unless adv-check
is set to http
.
-
Definition: Requested URI for HTTP health check
-
Type: string
-
Default value:
/
adv-check-http-status-code Jump to heading
Info
This attribute is ignored unless adv-check
is set to http
.
-
Definition: HTTP status code value to consider check successful
-
Type: integer
-
Default value:
200
Do you have any suggestions on how we can improve the content of this page?