API Objects Reference
L7 rules
This page applies to:
- HAProxy ALOHA - all versions
The rule type can be applied at different moments during request processing. Hence, some rules are available in service only, others in the farm only, and some in both.
Rules available once the incoming connection has been accepted:
tcpreqconn
(service only)
Rules available once the data has arrived on a client connection:
-
tcpreqcont
, available in both service and farm -
httpreq
, available in both service and farm -
redirect
, available in both service and farm
Rules available in service only to choose an alternative farm:
usefarm
Rules available in farm only to choose to force traffic to a server:
-
useserver
-
tcprspcont
Other rule types are available to perform third party actions in HAProxy:
-
Health checking:
tcpcheck
-
Stickiness:
stickreq
,stickrsp
tcpreqconn Jump to heading
Definition: Perform an action on an incoming connection:
type Jump to heading
-
Definition: action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
accept | Accept an incoming connection |
reject | Reject an incoming connection |
cond Jump to heading
-
Definition: Condition to apply the rule
-
Type: enum
-
Default value: Positive match
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
httpreq Jump to heading
Definition: Perform an action on an incoming HTTP request.
-
To create an L7 rule for
httpreq
, you must use the URL/api/2/*/*/l7/<objecttype>/<objectname>/rule/<ruletype>/<number>
. -
The rule
<number>
can have any of the following values:
Value | Description |
---|---|
Tail | Get the first rule of the list |
Head | Get the last rule of the list |
A positive integer | Get the rule pointed by the integer |
type Jump to heading
-
Definition: action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
allow | Accept incoming request; stop evaluation of next rules |
deny | Reject incoming request; stop evaluation of next rules |
auth | Stop the evaluation of the rules; answer with a 401 or 407 to invite the client to authenticate itself |
redirect | Perform an HTTP redirection rule |
tarpit | Block the request during timeout tarpit period of time; stop evaluation of next rules |
add-header | Append an HTTP header field in the request |
set-header | Append an HTTP header field in the request; but delete first any field with the same name |
set-log-level | Change the log level for the current HTTP (req+resp) session |
auth-realm Jump to heading
Info
This is ignored if httpreq is not set to auth.
-
Definition: Authentication realm string
-
Type: string
-
Default value: none
log-level Jump to heading
Info
This is ignored if httpreq is not set to set-log-level.
-
Definition: Log level to use
-
Type: enum
-
Default value: none
-
Values: Standard syslog levels: debug, info, notice, warning, err, crit, alert, emerg or their integer equivalent, respectively 0, 1, 2, 3, 4, 5, 6, 7* A specific keyword silent to prevent generating the log line, or integer 8.
redir-type Jump to heading
Info
This is ignored if httpreq is not set to redirect.
-
Definition: Type of HTTP redirection to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
location | Exact redir-to value is placed in the Location header field |
prefix | Use redir-to concatened to current URI path (including query string) to create the Location header |
scheme | Use to change the URL scheme: redir-to is concatenated to the first occurrence of the Host header and the URI path, including the query string |
redir-to Jump to heading
Info
This is ignored if httpreq is not set to redirect.
-
Definition: A string to use when building the Location header
-
Type: string
-
Default value: none
redir-code Jump to heading
Info
This is ignored if httpreq is not set to redirect.
-
Definition: HTTP Status code used to perform the redirection (usually, 301 or 302)
-
Type: integer
-
Default value: none
hdr-name Jump to heading
Info
This is ignored if httpreq is not set to add-header or set-header.
-
Definition: Name of the HTTP header field
-
Type: string
-
Default value: none
cond Jump to heading
-
Definition: Condition to apply the rule
-
Type: enum
-
Default value: Positive match
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
redirect Jump to heading
We highly recommend using thehttpreq redirect rule rather than the redirect rule. It is easier to understand a configuration that uses only http-request rules instead of a mix of different types of directives.
type Jump to heading
-
Definition: Type of HTTP redirection to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
location | Exact to value is placed in the Location header field |
prefix | Use to concatened to current URI path (including query string) to create the Location header |
scheme | Use to change the URL scheme: redir-to is concatenated to the first occurrence of the Host header and the URI path, including the query string |
to Jump to heading
-
Definition: String to use when building the Location header
-
Type: string
-
Default value: none
code Jump to heading
-
Definition: HTTP Status code used to perform the redirection (usually 301 or 302)
-
Type: enum
-
Default value:
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
usefarm Jump to heading
Definition: Content switching rule to route traffic to a farm.
target-farm Jump to heading
-
Definition: Name of the farm to route the traffic to
-
Type: string
-
Default value: none
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
tcprspcont Jump to heading
Definition: Perform an action on a session response.
type Jump to heading
-
Definition: Action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
accept | Accept an incoming connection |
reject | Reject an incoming connection |
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
useserver Jump to heading
Definition: content switching rule to route traffic to a server.
target-server Jump to heading
-
Definition: Name of the server to route the traffic to
-
Type: string
-
Default value: none
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
stickreq Jump to heading
Definition: Match and/or set stickiness during the request.
type Jump to heading
-
Definition: Action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
matchandstore | Match the pattern in the table and stores it if not found |
matchonly | Match the pattern in the table |
storeonly | Store the pattern in the table |
pattern Jump to heading
-
Definition: Fetch expression to the retrieve key used to perform stickiness
-
Type: string
-
Default value: none
table Jump to heading
-
Definition: Stick table name
-
Type: string
-
Default value: none; if not set, use the stick table from the local farm
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
-
Values:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
stickrsp Jump to heading
Definition: Match and/or set stickiness during the request.
type Jump to heading
-
Definition: Action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
storeonly | Store the pattern in the table |
pattern Jump to heading
-
Definition: Fetch expression to the retrieve key used to perform stickiness
-
Type: string
-
Default value: none
table Jump to heading
-
Definition: Stick table name
-
Type: string
-
Default value: none; if not set, use the stick table from the local farm
cond Jump to heading
-
Definition: condition to apply the rule
-
Type: Positive match
-
Default value:
Value | Description |
---|---|
if | Positive match: apply the rule if cond_test matches |
unless | Negative match: apply the rule if cond_test does not match |
cond-test Jump to heading
-
Definition: HAProxy ACL(s) to perform conditions
-
Type: string
-
Default value: none
tcpcheck Jump to heading
Definition: Send or expect a sequence to perform a server health check.
type Jump to heading
-
Definition: Action to perform
-
Type: enum
-
Default value: none
Value | Description |
---|---|
connect | Establish a TCP connection to the server |
send | Send raw data to the server |
expect | Match content in data returned by the server |
connect-port Jump to heading
Info
This is ignored if type is not set to connect.
-
Definition: TCP to connect to
-
Type: integer
-
Default value: Server’s port
connect-ssl Jump to heading
Info
This is ignored if type is not set to connect.
-
Definition: Establish a TLS connection
-
Type: enum; value accepted: enabled
-
Default value: disabled
expect-failonmatch Jump to heading
Info
This is ignored if type is not set to expect.
-
Definition: Pattern (string or hexadecimal representation) to match against server response
-
Type: string
-
Default value: none
expect-match Jump to heading
Info
This is ignored if type is not set to expect.
-
Definition: type of matching to perform
-
Type: enum
-
Default value: string
Value | Description |
---|---|
binary | Binary (hexadecimal) matching |
rstring | Regular expression |
string | Regular string comparison |
expect-pattern Jump to heading
Info
This is ignored if type is not set to expect.
-
Definition: Pattern (string or hexadecimal representation) to match against server response.
-
Type: string
-
Default value: none
send-data Jump to heading
Info
This is ignored if type is not set to send.
-
Definition: Data to send to the server
-
Type: enum
-
Default value: string
send-format Jump to heading
Info
This is ignored if type is not set to send.
-
Definition: Format of the data to send to the server
-
Type: enum
-
Default value: string
Value | Description |
---|---|
binary | Binary (hexadecimal) matching |
string | Regular string comparison |
Do you have any suggestions on how we can improve the content of this page?