Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/7.2
HAProxy by HTTP
Overview
The template to monitor HAProxy by Zabbix that works without any external scripts. Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
The template collects metrics by polling the HAProxy stats page with HTTP agent.
Requirements
Zabbix version: 7.2 and higher.
Tested versions
This template has been tested on:
- HAProxy 1.8
Configuration
Zabbix should be configured according to the instructions in the Templates out of the box section.
Setup
- Set up the
HAProxy stats page
.
If you want to use authentication, set the username and password in the stats auth
option of the configuration file.
The example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
-
Set the hostname or IP address of the HAProxy stats host or container in the
{$HAPROXY.STATS.HOST}
macro. You can also change the status page port in the{$HAPROXY.STATS.PORT}
macro, the status page scheme in the{$HAPROXY.STATS.SCHEME}
macro and the status page path in the{$HAPROXY.STATS.PATH}
macro if necessary. -
If you have enabled authentication in the HAProxy configuration file in step 1, set the username and password in the
{$HAPROXY.USERNAME}
and{$HAPROXY.PASSWORD}
macros.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page (http/https). |
http |
{$HAPROXY.STATS.HOST} | The hostname or IP address of the HAProxy stats host or container. |
<SET HAPROXY HOST> |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
|
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
|
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
Items
Name | Description | Type | Key and additional info |
---|---|---|---|
Get stats | HAProxy Statistics Report in CSV format |
HTTP agent | haproxy.get Preprocessing
|
Get nodes | Array for LLD rules. |
Dependent item | haproxy.get.nodes Preprocessing
|
Get stats page | HAProxy Statistics Report HTML |
HTTP agent | haproxy.get_html |
Version | Dependent item | haproxy.version Preprocessing
|
|
Uptime | Dependent item | haproxy.uptime Preprocessing
|
|
Service status | Simple check | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] Preprocessing
|
|
Service response time | Simple check | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed | HAProxy version has changed. Acknowledge to close the problem manually. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
Info | Manual close: Yes |
HAProxy: has been restarted | Uptime is less than 10 minutes. |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
Info | Manual close: Yes |
HAProxy: Service is down | last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"])=0 |
Average | Manual close: Yes | |
HAProxy: Service response time is too high | min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
Warning | Manual close: Yes Depends on:
|
LLD rule Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
Dependent item | haproxy.backend.discovery |
Item prototypes for Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend {#PXNAME}: Raw data | The raw data of the Backend with the name |
Dependent item | haproxy.backend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
Dependent item | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
Dependent item | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of active servers | Number of active servers. |
Dependent item | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
Dependent item | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Weight | Total effective weight. |
Dependent item | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Backend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Average | |
HAProxy: backend {#PXNAME}: Average response time is high | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Number of responses with error is high | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Current number of requests unassigned in queue is high | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
Warning |
LLD rule Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend discovery | Discovery frontends |
Dependent item | haproxy.frontend.discovery |
Item prototypes for Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend {#PXNAME}: Raw data | The raw data of the Frontend with the name |
Dependent item | haproxy.frontend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
Dependent item | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Requests rate | HTTP requests per second |
Dependent item | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
Dependent item | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
Dependent item | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
Dependent item | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
Calculated | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] |
Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
Dependent item | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
Dependent item | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
Dependent item | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
Dependent item | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Frontend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: frontend {#PXNAME}: Session utilization is high | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
Warning | |
HAProxy: frontend {#PXNAME}: Number of request errors is high | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
Warning | |
HAProxy: frontend {#PXNAME}: Number of requests denied is high | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
Warning |
LLD rule Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server discovery | Discovery servers |
Dependent item | haproxy.server.discovery |
Item prototypes for Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server {#PXNAME} {#SVNAME}: Raw data | The raw data of the Server named |
Dependent item | haproxy.server.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Status | Dependent item | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing
|
|
{#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
Dependent item | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
Dependent item | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
Dependent item | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Weight | Effective weight. |
Dependent item | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
Dependent item | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
Dependent item | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
Dependent item | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Server discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Average response time is high | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Number of responses with error is high | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is high | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK|^$)")=0 |
Warning | Depends on:
|
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide feedback, discuss the template, or ask for help at ZABBIX forums
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/7.0
HAProxy by HTTP
Overview
The template to monitor HAProxy by Zabbix that works without any external scripts. Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
The template collects metrics by polling the HAProxy stats page with HTTP agent.
Requirements
Zabbix version: 7.0 and higher.
Tested versions
This template has been tested on:
- HAProxy 1.8
Configuration
Zabbix should be configured according to the instructions in the Templates out of the box section.
Setup
- Set up the
HAProxy stats page
.
If you want to use authentication, set the username and password in the stats auth
option of the configuration file.
The example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
-
Set the hostname or IP address of the HAProxy stats host or container in the
{$HAPROXY.STATS.HOST}
macro. You can also change the status page port in the{$HAPROXY.STATS.PORT}
macro, the status page scheme in the{$HAPROXY.STATS.SCHEME}
macro and the status page path in the{$HAPROXY.STATS.PATH}
macro if necessary. -
If you have enabled authentication in the HAProxy configuration file in step 1, set the username and password in the
{$HAPROXY.USERNAME}
and{$HAPROXY.PASSWORD}
macros.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page (http/https). |
http |
{$HAPROXY.STATS.HOST} | The hostname or IP address of the HAProxy stats host or container. |
<SET HAPROXY HOST> |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
|
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
|
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
Items
Name | Description | Type | Key and additional info |
---|---|---|---|
Get stats | HAProxy Statistics Report in CSV format |
HTTP agent | haproxy.get Preprocessing
|
Get nodes | Array for LLD rules. |
Dependent item | haproxy.get.nodes Preprocessing
|
Get stats page | HAProxy Statistics Report HTML |
HTTP agent | haproxy.get_html |
Version | Dependent item | haproxy.version Preprocessing
|
|
Uptime | Dependent item | haproxy.uptime Preprocessing
|
|
Service status | Simple check | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] Preprocessing
|
|
Service response time | Simple check | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed | HAProxy version has changed. Acknowledge to close the problem manually. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
Info | Manual close: Yes |
HAProxy: has been restarted | Uptime is less than 10 minutes. |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
Info | Manual close: Yes |
HAProxy: Service is down | last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"])=0 |
Average | Manual close: Yes | |
HAProxy: Service response time is too high | min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
Warning | Manual close: Yes Depends on:
|
LLD rule Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
Dependent item | haproxy.backend.discovery |
Item prototypes for Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend {#PXNAME}: Raw data | The raw data of the Backend with the name |
Dependent item | haproxy.backend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
Dependent item | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
Dependent item | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of active servers | Number of active servers. |
Dependent item | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
Dependent item | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Backend {#PXNAME}: Weight | Total effective weight. |
Dependent item | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Backend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Average | |
HAProxy: backend {#PXNAME}: Average response time is high | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Number of responses with error is high | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Current number of requests unassigned in queue is high | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
Warning | |
HAProxy: backend {#PXNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
Warning |
LLD rule Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend discovery | Discovery frontends |
Dependent item | haproxy.frontend.discovery |
Item prototypes for Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend {#PXNAME}: Raw data | The raw data of the Frontend with the name |
Dependent item | haproxy.frontend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
Dependent item | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Requests rate | HTTP requests per second |
Dependent item | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
Dependent item | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
Dependent item | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
Dependent item | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
Calculated | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] |
Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
Dependent item | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
Dependent item | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
Dependent item | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
Dependent item | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Frontend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: frontend {#PXNAME}: Session utilization is high | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
Warning | |
HAProxy: frontend {#PXNAME}: Number of request errors is high | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
Warning | |
HAProxy: frontend {#PXNAME}: Number of requests denied is high | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
Warning |
LLD rule Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server discovery | Discovery servers |
Dependent item | haproxy.server.discovery |
Item prototypes for Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server {#PXNAME} {#SVNAME}: Raw data | The raw data of the Server named |
Dependent item | haproxy.server.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Status | Dependent item | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing
|
|
{#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
Dependent item | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
Dependent item | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
Dependent item | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Weight | Effective weight. |
Dependent item | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
Dependent item | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
Dependent item | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
{#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
Dependent item | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Server discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Average response time is high | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Number of responses with error is high | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is high | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
Warning | |
HAProxy: {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK|^$)")=0 |
Warning | Depends on:
|
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide feedback, discuss the template, or ask for help at ZABBIX forums
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/6.4
HAProxy by HTTP
Overview
The template to monitor HAProxy by Zabbix that works without any external scripts. Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
The template collects metrics by polling the HAProxy stats page with HTTP agent.
Requirements
Zabbix version: 6.4 and higher.
Tested versions
This template has been tested on:
- HAProxy 1.8
Configuration
Zabbix should be configured according to the instructions in the Templates out of the box section.
Setup
- Set up the
HAProxy stats page
.
If you want to use authentication, set the username and password in the stats auth
option of the configuration file.
The example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
-
Set the hostname or IP address of the HAProxy stats host or container in the
{$HAPROXY.STATS.HOST}
macro. You can also change the status page port in the{$HAPROXY.STATS.PORT}
macro, the status page scheme in the{$HAPROXY.STATS.SCHEME}
macro and the status page path in the{$HAPROXY.STATS.PATH}
macro if necessary. -
If you have enabled authentication in the HAProxy configuration file in step 1, set the username and password in the
{$HAPROXY.USERNAME}
and{$HAPROXY.PASSWORD}
macros.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page (http/https). |
http |
{$HAPROXY.STATS.HOST} | The hostname or IP address of the HAProxy stats host or container. |
<SET HAPROXY HOST> |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
|
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
|
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
Items
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy: Get stats | HAProxy Statistics Report in CSV format |
HTTP agent | haproxy.get Preprocessing
|
HAProxy: Get nodes | Array for LLD rules. |
Dependent item | haproxy.get.nodes Preprocessing
|
HAProxy: Get stats page | HAProxy Statistics Report HTML |
HTTP agent | haproxy.get_html |
HAProxy: Version | Dependent item | haproxy.version Preprocessing
|
|
HAProxy: Uptime | Dependent item | haproxy.uptime Preprocessing
|
|
HAProxy: Service status | Simple check | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] Preprocessing
|
|
HAProxy: Service response time | Simple check | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"] |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed | HAProxy version has changed. Acknowledge to close the problem manually. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
Info | Manual close: Yes |
HAProxy: has been restarted | Uptime is less than 10 minutes. |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
Info | Manual close: Yes |
HAProxy: Service is down | last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"])=0 |
Average | Manual close: Yes | |
HAProxy: Service response time is too high | min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{$HAPROXY.STATS.HOST}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
Warning | Manual close: Yes Depends on:
|
LLD rule Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
Dependent item | haproxy.backend.discovery |
Item prototypes for Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Backend {#PXNAME}: Raw data | The raw data of the Backend with the name |
Dependent item | haproxy.backend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
Dependent item | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
Dependent item | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of active servers | Number of active servers. |
Dependent item | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
Dependent item | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Weight | Total effective weight. |
Dependent item | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Backend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Average | |
HAProxy backend {#PXNAME}: Average response time is high | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Number of responses with error is high | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Current number of requests unassigned in queue is high | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
Warning |
LLD rule Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend discovery | Discovery frontends |
Dependent item | haproxy.frontend.discovery |
Item prototypes for Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Frontend {#PXNAME}: Raw data | The raw data of the Frontend with the name |
Dependent item | haproxy.frontend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
Dependent item | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Requests rate | HTTP requests per second |
Dependent item | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
Dependent item | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
Dependent item | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
Dependent item | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
Calculated | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] |
HAProxy Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
Dependent item | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
Dependent item | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
Dependent item | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
Dependent item | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Frontend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy frontend {#PXNAME}: Session utilization is high | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
Warning | |
HAProxy frontend {#PXNAME}: Number of request errors is high | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
Warning | |
HAProxy frontend {#PXNAME}: Number of requests denied is high | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
Warning |
LLD rule Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server discovery | Discovery servers |
Dependent item | haproxy.server.discovery |
Item prototypes for Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Server {#PXNAME} {#SVNAME}: Raw data | The raw data of the Server named |
Dependent item | haproxy.server.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Status | Dependent item | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing
|
|
HAProxy {#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
Dependent item | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
Dependent item | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
Dependent item | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Weight | Effective weight. |
Dependent item | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
Dependent item | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
Dependent item | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
Dependent item | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Server discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Average response time is high | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Number of responses with error is high | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is high | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK|^$)")=0 |
Warning | Depends on:
|
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide feedback, discuss the template, or ask for help at ZABBIX forums
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/6.2
HAProxy by HTTP
Overview
For Zabbix version: 6.2 and higher
The template to monitor HAProxy by Zabbix that works without any external scripts.
Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
Template HAProxy by HTTP
collects metrics by polling HAProxy Stats Page with HTTP agent remotely.
Note that this solution supports https and redirects.
This template was tested on:
- HAProxy, version 1.8
Setup
See Zabbix template operation for basic instructions.
Setup HAProxy Stats Page.
Example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
If you use another location, don't forget to change the macros {$HAPROXY.STATS.SCHEME},{HOST.CONN}, {$HAPROXY.STATS.PORT},{$HAPROXY.STATS.PATH}.
If you want to use authentication, set the username and password in the "stats auth" option of the configuration file and in the macros {$HAPROXY.USERNAME},{$HAPROXY.PASSWORD}.
Zabbix configuration
No specific Zabbix configuration is required.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
`` |
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page(http/https). |
http |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
`` |
Template links
There are no template links in this template.
Discovery rules
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
DEPENDENT | haproxy.backend.discovery Filter: AND- {#SVNAME} MATCHES_REGEX - {#MODE} MATCHES_REGEX `http |
Frontend discovery | Discovery frontends |
DEPENDENT | haproxy.frontend.discovery Filter: AND- {#SVNAME} MATCHES_REGEX - {#MODE} MATCHES_REGEX `http |
Server discovery | Discovery servers |
DEPENDENT | haproxy.server.discovery Filter: AND- {#SVNAME} NOT_MATCHES_REGEX `FRONTEND |
Items collected
Group | Name | Description | Type | Key and additional info |
---|---|---|---|---|
HAProxy | HAProxy: Version | - |
DEPENDENT | haproxy.version Preprocessing: - REGEX: ⛔️ON_FAIL: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Uptime | - |
DEPENDENT | haproxy.uptime Preprocessing: - JAVASCRIPT: |
HAProxy | HAProxy: Service status | - |
SIMPLE | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] Preprocessing: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Service response time | - |
SIMPLE | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] |
HAProxy | HAProxy Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
DEPENDENT | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
DEPENDENT | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of active servers | Number of active servers. |
DEPENDENT | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
DEPENDENT | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Weight | Total effective weight. |
DEPENDENT | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
DEPENDENT | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Requests rate | HTTP requests per second |
DEPENDENT | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
DEPENDENT | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
DEPENDENT | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
DEPENDENT | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
CALCULATED | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] Expression: last(//haproxy.frontend.scur[{#PXNAME},{#SVNAME}]) / last(//haproxy.frontend.slim[{#PXNAME},{#SVNAME}]) * 100 |
HAProxy | HAProxy Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
DEPENDENT | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
DEPENDENT | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
DEPENDENT | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
DEPENDENT | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status | DEPENDENT | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
|
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
DEPENDENT | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
DEPENDENT | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
DEPENDENT | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Weight | Effective weight. |
DEPENDENT | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
DEPENDENT | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: - MATCHES_REGEX: ⛔️ON_FAIL: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
DEPENDENT | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
DEPENDENT | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix raw items | HAProxy: Get stats | HAProxy Statistics Report in CSV format |
HTTP_AGENT | haproxy.get Preprocessing: - REGEX: - CSV_TO_JSON: |
Zabbix raw items | HAProxy: Get nodes | Array for LLD rules. |
DEPENDENT | haproxy.get.nodes Preprocessing: - JAVASCRIPT: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix raw items | HAProxy: Get stats page | HAProxy Statistics Report HTML |
HTTP_AGENT | haproxy.get_html |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed | HAProxy version has changed. Ack to close. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
INFO | Manual close: YES |
HAProxy: has been restarted | Uptime is less than 10 minutes |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
INFO | Manual close: YES |
HAProxy: Service is down | - |
last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"])=0 |
AVERAGE | Manual close: YES |
HAProxy: Service response time is too high | - |
min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
WARNING | Manual close: YES Depends on: - HAProxy: Service is down |
HAProxy backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
AVERAGE | |
HAProxy backend {#PXNAME}: Average response time is high | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Number of responses with error is high | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Current number of requests unassigned in queue is high | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Session utilization is high | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of request errors is high | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of requests denied is high | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average response time is high | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Number of responses with error is high | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is high | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
`find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK | ^$)")=0` | WARNING |
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide feedback, discuss the template or ask for help with it at ZABBIX forums.
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/6.0
HAProxy by HTTP
Overview
The template to monitor HAProxy by Zabbix that works without any external scripts. Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
Template HAProxy by HTTP
collects metrics by polling HAProxy Stats Page with HTTP agent remotely.
Note that this solution supports https and redirects.
Requirements
Zabbix version: 6.0 and higher.
Tested versions
This template has been tested on:
- HAProxy 1.8
Configuration
Zabbix should be configured according to the instructions in the Templates out of the box section.
Setup
Setup HAProxy Stats Page.
Example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
If you use another location, don't forget to change the macros {$HAPROXY.STATS.SCHEME},{HOST.CONN}, {$HAPROXY.STATS.PORT},{$HAPROXY.STATS.PATH}.
If you want to use authentication, set the username and password in the "stats auth" option of the configuration file and in the macros {$HAPROXY.USERNAME},{$HAPROXY.PASSWORD}.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page(http/https). |
http |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
|
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
|
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
Items
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy: Get stats | HAProxy Statistics Report in CSV format |
HTTP agent | haproxy.get Preprocessing
|
HAProxy: Get nodes | Array for LLD rules. |
Dependent item | haproxy.get.nodes Preprocessing
|
HAProxy: Get stats page | HAProxy Statistics Report HTML |
HTTP agent | haproxy.get_html |
HAProxy: Version | Dependent item | haproxy.version Preprocessing
|
|
HAProxy: Uptime | Dependent item | haproxy.uptime Preprocessing
|
|
HAProxy: Service status | Simple check | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] Preprocessing
|
|
HAProxy: Service response time | Simple check | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed | HAProxy version has changed. Acknowledge to close the problem manually. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
Info | Manual close: Yes |
HAProxy: has been restarted | Uptime is less than 10 minutes. |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
Info | Manual close: Yes |
HAProxy: Service is down | last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"])=0 |
Average | Manual close: Yes | |
HAProxy: Service response time is too high | min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
Warning | Manual close: Yes Depends on:
|
LLD rule Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
Dependent item | haproxy.backend.discovery |
Item prototypes for Backend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Backend {#PXNAME}: Raw data | The raw data of the Backend with the name |
Dependent item | haproxy.backend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
Dependent item | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
Dependent item | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
Dependent item | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of active servers | Number of active servers. |
Dependent item | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
Dependent item | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Backend {#PXNAME}: Weight | Total effective weight. |
Dependent item | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Backend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Average | |
HAProxy backend {#PXNAME}: Average response time is high | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Number of responses with error is high | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Current number of requests unassigned in queue is high | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
Warning | |
HAProxy backend {#PXNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
Warning |
LLD rule Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Frontend discovery | Discovery frontends |
Dependent item | haproxy.frontend.discovery |
Item prototypes for Frontend discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Frontend {#PXNAME}: Raw data | The raw data of the Frontend with the name |
Dependent item | haproxy.frontend.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
Dependent item | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Requests rate | HTTP requests per second |
Dependent item | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
Dependent item | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
Dependent item | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
Dependent item | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
Calculated | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] |
HAProxy Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
Dependent item | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
Dependent item | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
Dependent item | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
Dependent item | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Frontend discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy frontend {#PXNAME}: Session utilization is high | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
Warning | |
HAProxy frontend {#PXNAME}: Number of request errors is high | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
Warning | |
HAProxy frontend {#PXNAME}: Number of requests denied is high | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
Warning |
LLD rule Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
Server discovery | Discovery servers |
Dependent item | haproxy.server.discovery |
Item prototypes for Server discovery
Name | Description | Type | Key and additional info |
---|---|---|---|
HAProxy Server {#PXNAME} {#SVNAME}: Raw data | The raw data of the Server named |
Dependent item | haproxy.server.raw[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Status | Dependent item | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing
|
|
HAProxy {#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
Dependent item | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
Dependent item | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
Dependent item | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
Dependent item | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
Dependent item | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
Dependent item | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
Dependent item | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
Dependent item | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
Dependent item | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
Dependent item | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
Dependent item | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
Dependent item | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
Dependent item | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
Dependent item | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
Dependent item | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
Dependent item | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
Dependent item | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Weight | Effective weight. |
Dependent item | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
Dependent item | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
Dependent item | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing
|
HAProxy {#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
Dependent item | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing
|
Trigger prototypes for Server discovery
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Average response time is high | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Number of responses with error is high | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is high | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Average time spent in queue is high | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
Warning | |
HAProxy {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK|^$)")=0 |
Warning | Depends on:
|
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide feedback, discuss the template, or ask for help at ZABBIX forums
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/5.4
HAProxy by HTTP
Overview
For Zabbix version: 5.4 and higher
The template to monitor HAProxy by Zabbix that works without any external scripts.
Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
Template HAProxy by HTTP
collects metrics by polling HAProxy Stats Page with HTTP agent remotely.
Note that this solution supports https and redirects.
This template was tested on:
- HAProxy, version 1.8
Setup
See Zabbix template operation for basic instructions.
Setup HAProxy Stats Page.
Example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
If you use another location, don't forget to change the macros {$HAPROXY.STATS.SCHEME},{HOST.CONN}, {$HAPROXY.STATS.PORT},{$HAPROXY.STATS.PATH}.
If you want to use authentication, set the username and password in the "stats auth" option of the configuration file and in the macros {$HAPROXY.USERNAME},{$HAPROXY.PASSWORD}.
Zabbix configuration
No specific Zabbix configuration is required.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
`` |
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page(http/https). |
http |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
`` |
Template links
There are no template links in this template.
Discovery rules
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
DEPENDENT | haproxy.backend.discovery Filter: AND- {#SVNAME} MATCHES_REGEX - {#MODE} MATCHES_REGEX `http |
Frontend discovery | Discovery frontends |
DEPENDENT | haproxy.frontend.discovery Filter: AND- {#SVNAME} MATCHES_REGEX - {#MODE} MATCHES_REGEX `http |
Server discovery | Discovery servers |
DEPENDENT | haproxy.server.discovery Filter: AND- {#SVNAME} NOT_MATCHES_REGEX `FRONTEND |
Items collected
Group | Name | Description | Type | Key and additional info |
---|---|---|---|---|
HAProxy | HAProxy: Version | - |
DEPENDENT | haproxy.version Preprocessing: - REGEX: ⛔️ON_FAIL: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Uptime | - |
DEPENDENT | haproxy.uptime Preprocessing: - JAVASCRIPT: |
HAProxy | HAProxy: Service status | - |
SIMPLE | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] Preprocessing: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Service response time | - |
SIMPLE | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] |
HAProxy | HAProxy Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
DEPENDENT | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
DEPENDENT | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of active servers | Number of active servers. |
DEPENDENT | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
DEPENDENT | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Weight | Total effective weight. |
DEPENDENT | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
DEPENDENT | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Requests rate | HTTP requests per second |
DEPENDENT | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
DEPENDENT | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
DEPENDENT | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
DEPENDENT | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
CALCULATED | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] Expression: last(//haproxy.frontend.scur[{#PXNAME},{#SVNAME}]) / last(//haproxy.frontend.slim[{#PXNAME},{#SVNAME}]) * 100 |
HAProxy | HAProxy Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
DEPENDENT | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
DEPENDENT | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
DEPENDENT | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
DEPENDENT | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status | DEPENDENT | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
|
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
DEPENDENT | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
DEPENDENT | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
DEPENDENT | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Weight | Effective weight. |
DEPENDENT | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
DEPENDENT | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: - MATCHES_REGEX: ⛔️ON_FAIL: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
DEPENDENT | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
DEPENDENT | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix_raw_items | HAProxy: Get stats | HAProxy Statistics Report in CSV format |
HTTP_AGENT | haproxy.get Preprocessing: - REGEX: - CSV_TO_JSON: |
Zabbix_raw_items | HAProxy: Get nodes | Array for LLD rules. |
DEPENDENT | haproxy.get.nodes Preprocessing: - JAVASCRIPT: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix_raw_items | HAProxy: Get stats page | HAProxy Statistics Report HTML |
HTTP_AGENT | haproxy.get_html |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed (new version: {ITEM.VALUE}) | HAProxy version has changed. Ack to close. |
last(/HAProxy by HTTP/haproxy.version,#1)<>last(/HAProxy by HTTP/haproxy.version,#2) and length(last(/HAProxy by HTTP/haproxy.version))>0 |
INFO | Manual close: YES |
HAProxy: has been restarted (uptime < 10m) | Uptime is less than 10 minutes |
last(/HAProxy by HTTP/haproxy.uptime)<10m |
INFO | Manual close: YES |
HAProxy: Service is down | - |
last(/HAProxy by HTTP/net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"])=0 |
AVERAGE | Manual close: YES |
HAProxy: Service response time is too high (over {$HAPROXY.RESPONSE_TIME.MAX.WARN} for 5m) | - |
min(/HAProxy by HTTP/net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"],5m)>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
WARNING | Manual close: YES Depends on: - HAProxy: Service is down |
HAProxy backend {#PXNAME}: Server is DOWN | Backend is not available. |
count(/HAProxy by HTTP/haproxy.backend.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
AVERAGE | |
HAProxy backend {#PXNAME}: Average response time is more than {$HAPROXY.BACK_RTIME.MAX.WARN} for 5m | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_RTIME.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Number of responses with error is more than {$HAPROXY.BACK_ERESP.MAX.WARN} for 5m | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_ERESP.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Current number of requests unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN} for 5m | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QCUR.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Average time spent in queue is more than {$HAPROXY.BACK_QTIME.MAX.WARN} for 5m | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.backend.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.BACK_QTIME.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Session utilization is more than {$HAPROXY.FRONT_SUTIL.MAX.WARN}% for 5m | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
min(/HAProxy by HTTP/haproxy.frontend.sutil[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN} for 5m | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of requests denied is more than {$HAPROXY.FRONT_DREQ.MAX.WARN} for 5m | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
count(/HAProxy by HTTP/haproxy.server.status[{#PXNAME},{#SVNAME}],#5,"eq","DOWN")=5 |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average response time is more than {$HAPROXY.SERVER_RTIME.MAX.WARN} for 5m | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.rtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Number of responses with error is more than {$HAPROXY.SERVER_ERESP.MAX.WARN} for 5m | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN} for 5m | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qcur[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average time spent in queue is more than {$HAPROXY.SERVER_QTIME.MAX.WARN} for 5m | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
min(/HAProxy by HTTP/haproxy.server.qtime[{#PXNAME},{#SVNAME}],5m)>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
`find(/HAProxy by HTTP/haproxy.server.check_status[{#PXNAME},{#SVNAME}],#3,"regexp","(?:L[4-7]OK | ^$)")=0` | WARNING |
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide a feedback, discuss the template or ask for help with it at ZABBIX forums.
Source: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/app/haproxy_http?at=release/5.0
Template App HAProxy by HTTP
Overview
For Zabbix version: 5.0 and higher
The template to monitor HAProxy by Zabbix that works without any external scripts.
Most of the metrics are collected in one go, thanks to Zabbix bulk data collection.
Template HAProxy by HTTP
collects metrics by polling HAProxy Stats Page with HTTP agent remotely.
Note that this solution supports https and redirects.
This template was tested on:
- HAProxy, version 1.8
- Zabbix, version 5.0
Setup
See Zabbix template operation for basic instructions.
Setup HAProxy Stats Page.
Example configuration of HAProxy:
frontend stats
bind *:8404
stats enable
stats uri /stats
stats refresh 10s
#stats auth Username:Password # Authentication credentials
If you use another location, don't forget to change the macros {$HAPROXY.STATS.SCHEME},{HOST.CONN}, {$HAPROXY.STATS.PORT},{$HAPROXY.STATS.PATH}.
If you want to use authentication, set the username and password in the "stats auth" option of the configuration file and in the macros {$HAPROXY.USERNAME},{$HAPROXY.PASSWORD}.
Zabbix configuration
No specific Zabbix configuration is required.
Macros used
Name | Description | Default |
---|---|---|
{$HAPROXY.BACK_ERESP.MAX.WARN} | Maximum of responses with error on Backend for trigger expression. |
10 |
{$HAPROXY.BACK_QCUR.MAX.WARN} | Maximum number of requests on Backend unassigned in queue for trigger expression. |
10 |
{$HAPROXY.BACK_QTIME.MAX.WARN} | Maximum of average time spent in queue on Backend for trigger expression. |
10s |
{$HAPROXY.BACK_RTIME.MAX.WARN} | Maximum of average Backend response time for trigger expression. |
10s |
{$HAPROXY.FRONT_DREQ.MAX.WARN} | The HAProxy maximum denied requests for trigger expression. |
10 |
{$HAPROXY.FRONT_EREQ.MAX.WARN} | The HAProxy maximum number of request errors for trigger expression. |
10 |
{$HAPROXY.FRONT_SUTIL.MAX.WARN} | Maximum of session usage percentage on frontend for trigger expression. |
80 |
{$HAPROXY.PASSWORD} | The password of the HAProxy stats page. |
`` |
{$HAPROXY.RESPONSE_TIME.MAX.WARN} | The HAProxy stats page maximum response time in seconds for trigger expression. |
10s |
{$HAPROXY.SERVER_ERESP.MAX.WARN} | Maximum of responses with error on server for trigger expression. |
10 |
{$HAPROXY.SERVER_QCUR.MAX.WARN} | Maximum number of requests on server unassigned in queue for trigger expression. |
10 |
{$HAPROXY.SERVER_QTIME.MAX.WARN} | Maximum of average time spent in queue on server for trigger expression. |
10s |
{$HAPROXY.SERVER_RTIME.MAX.WARN} | Maximum of average server response time for trigger expression. |
10s |
{$HAPROXY.STATS.PATH} | The path of the HAProxy stats page. |
stats |
{$HAPROXY.STATS.PORT} | The port of the HAProxy stats host or container. |
8404 |
{$HAPROXY.STATS.SCHEME} | The scheme of HAProxy stats page(http/https). |
http |
{$HAPROXY.USERNAME} | The username of the HAProxy stats page. |
`` |
Template links
There are no template links in this template.
Discovery rules
Name | Description | Type | Key and additional info |
---|---|---|---|
Backend discovery | Discovery backends |
DEPENDENT | haproxy.backend.discovery Filter: AND- A: {#SVNAME} MATCHES_REGEX - B: {#MODE} MATCHES_REGEX `http |
Frontend discovery | Discovery frontends |
DEPENDENT | haproxy.frontend.discovery Filter: AND- A: {#SVNAME} MATCHES_REGEX - B: {#MODE} MATCHES_REGEX `http |
Server discovery | Discovery servers |
DEPENDENT | haproxy.server.discovery Filter: AND- A: {#SVNAME} NOT_MATCHES_REGEX `FRONTEND |
Items collected
Group | Name | Description | Type | Key and additional info |
---|---|---|---|---|
HAProxy | HAProxy: Version | - |
DEPENDENT | haproxy.version Preprocessing: - REGEX: ⛔️ON_FAIL: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Uptime | - |
DEPENDENT | haproxy.uptime Preprocessing: - JAVASCRIPT: |
HAProxy | HAProxy: Service status | - |
SIMPLE | net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] Preprocessing: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy: Service response time | - |
SIMPLE | net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"] |
HAProxy | HAProxy Backend {#PXNAME}: Status | Possible values: UP - The server is reporting as healthy. DOWN - The server is reporting as unhealthy and unable to receive requests. NOLB - You've added http-check disable-on-404 to the backend and the health checked URL has returned an HTTP 404 response. MAINT - The server has been disabled or put into maintenance mode. DRAIN - The server has been put into drain mode. no check - Health checks are not enabled for this server. |
DEPENDENT | haproxy.backend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Responses time | Average backend response time (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.backend.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.backend.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Response errors per second | Number of requests whose responses yielded an error |
DEPENDENT | haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.backend.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Backend {#PXNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests |
DEPENDENT | haproxy.backend.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy Backend {#PXNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.backend.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.backend.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.backend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.backend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.backend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.backend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.backend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.backend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Number of active servers | Number of active servers. |
DEPENDENT | haproxy.backend.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Number of backup servers | Number of backup servers. |
DEPENDENT | haproxy.backend.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Backend {#PXNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.backend.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Backend {#PXNAME}: Weight | Total effective weight. |
DEPENDENT | haproxy.backend.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Status | Possible values: OPEN, STOP. When Status is OPEN, the frontend is operating normally and ready to receive traffic. |
DEPENDENT | haproxy.frontend.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Requests rate | HTTP requests per second |
DEPENDENT | haproxy.frontend.req_rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Sessions rate | Number of sessions created per second |
DEPENDENT | haproxy.frontend.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Established sessions | The current number of established sessions. |
DEPENDENT | haproxy.frontend.scur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy Frontend {#PXNAME}: Session limits | The most simultaneous sessions that are allowed, as defined by the maxconn setting in the frontend. |
DEPENDENT | haproxy.frontend.slim[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy Frontend {#PXNAME}: Session utilization | Percentage of sessions used (scur / slim * 100). |
CALCULATED | haproxy.frontend.sutil[{#PXNAME},{#SVNAME}] Expression: last("haproxy.frontend.scur[{#PXNAME},{#SVNAME}]") / last("haproxy.frontend.slim[{#PXNAME},{#SVNAME}]") * 100 |
HAProxy | HAProxy Frontend {#PXNAME}: Request errors per second | Number of request errors per second. |
DEPENDENT | haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Denied requests per second | Requests denied due to security concerns (ACL-restricted) per second. |
DEPENDENT | haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.frontend.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.frontend.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.frontend.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.frontend.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Incoming traffic | Number of bits received by the frontend |
DEPENDENT | haproxy.frontend.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy Frontend {#PXNAME}: Outgoing traffic | Number of bits sent by the frontend |
DEPENDENT | haproxy.frontend.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status | DEPENDENT | haproxy.server.status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
|
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses time | Average server response time (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.rtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Errors connection per second | Number of requests that encountered an error attempting to connect to a backend server. |
DEPENDENT | haproxy.server.econ.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Responses denied per second | Responses denied due to security concerns (ACL-restricted). |
DEPENDENT | haproxy.server.dresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Response errors per second | Number of requests whose responses yielded an error. |
DEPENDENT | haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Unassigned requests | Current number of requests unassigned in queue. |
DEPENDENT | haproxy.server.qcur[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Time in queue | Average time spent in queue (in ms) for the last 1,024 requests. |
DEPENDENT | haproxy.server.qtime[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Redispatched requests per second | Number of times a request was redispatched to a different backend. |
DEPENDENT | haproxy.server.wredis.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Retried connections per second | Number of times a connection was retried. |
DEPENDENT | haproxy.server.wretr.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 1xx per second | Number of informational HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_1xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 2xx per second | Number of successful HTTP responses per second. |
DEPENDENT | haproxy.server.hrsp_2xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 3xx per second | Number of HTTP redirections per second. |
DEPENDENT | haproxy.server.hrsp_3xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 4xx per second | Number of HTTP client errors per second. |
DEPENDENT | haproxy.server.hrsp_4xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Number of responses with codes 5xx per second | Number of HTTP server errors per second. |
DEPENDENT | haproxy.server.hrsp_5xx.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Incoming traffic | Number of bits received by the backend |
DEPENDENT | haproxy.server.bin.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Outgoing traffic | Number of bits sent by the backend |
DEPENDENT | haproxy.server.bout.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - MULTIPLIER: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is active | Shows whether the server is active (marked with a Y) or a backup (marked with a -). |
DEPENDENT | haproxy.server.act[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server is backup | Shows whether the server is a backup (marked with a Y) or active (marked with a -). |
DEPENDENT | haproxy.server.bck[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Sessions per second | Cumulative number of sessions (end-to-end connections) per second. |
DEPENDENT | haproxy.server.stot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Weight | Effective weight. |
DEPENDENT | haproxy.server.weight[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Configured maxqueue | Configured maxqueue for the server, or nothing in the value is 0 (default, meaning no limit). |
DEPENDENT | haproxy.server.qlimit[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: - MATCHES_REGEX: ⛔️ON_FAIL: |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Server was selected per second | Number of times that server was selected. |
DEPENDENT | haproxy.server.lbtot.rate[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - CHANGE_PER_SECOND |
HAProxy | HAProxy {#PXNAME} {#SVNAME}: Status of last health check | Status of last health check, one of: UNK -> unknown INI -> initializing SOCKERR -> socket error L4OK -> check passed on layer 4, no upper layers testing enabled L4TOUT -> layer 1-4 timeout L4CON -> layer 1-4 connection problem, for example "Connection refused" (tcp rst) or "No route to host" (icmp) L6OK -> check passed on layer 6 L6TOUT -> layer 6 (SSL) timeout L6RSP -> layer 6 invalid response - protocol error L7OK -> check passed on layer 7 L7OKC -> check conditionally passed on layer 7, for example 404 with disable-on-404 L7TOUT -> layer 7 (HTTP/SMTP) timeout L7RSP -> layer 7 invalid response - protocol error L7STS -> layer 7 response error, for example HTTP 5xx Notice: If a check is currently running, the last known status will be reported, prefixed with "* ". e. g. "* L7OK". |
DEPENDENT | haproxy.server.check_status[{#PXNAME},{#SVNAME}] Preprocessing: - JSONPATH: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix_raw_items | HAProxy: Get stats | HAProxy Statistics Report in CSV format |
HTTP_AGENT | haproxy.get Preprocessing: - REGEX: - CSV_TO_JSON: |
Zabbix_raw_items | HAProxy: Get nodes | Array for LLD rules. |
DEPENDENT | haproxy.get.nodes Preprocessing: - JAVASCRIPT: - DISCARD_UNCHANGED_HEARTBEAT: |
Zabbix_raw_items | HAProxy: Get stats page | HAProxy Statistics Report HTML |
HTTP_AGENT | haproxy.get_html |
Triggers
Name | Description | Expression | Severity | Dependencies and additional info |
---|---|---|---|---|
HAProxy: Version has changed (new version: {ITEM.VALUE}) | HAProxy version has changed. Ack to close. |
{TEMPLATE_NAME:haproxy.version.diff()}=1 and {TEMPLATE_NAME:haproxy.version.strlen()}>0 |
INFO | Manual close: YES |
HAProxy: has been restarted (uptime < 10m) | Uptime is less than 10 minutes |
{TEMPLATE_NAME:haproxy.uptime.last()}<10m |
INFO | Manual close: YES |
HAProxy: Service is down | - |
{TEMPLATE_NAME:net.tcp.service["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"].last()}=0 |
AVERAGE | Manual close: YES |
HAProxy: Service response time is too high (over {$HAPROXY.RESPONSE_TIME.MAX.WARN} for 5m) | - |
{TEMPLATE_NAME:net.tcp.service.perf["{$HAPROXY.STATS.SCHEME}","{HOST.CONN}","{$HAPROXY.STATS.PORT}"].min(5m)}>{$HAPROXY.RESPONSE_TIME.MAX.WARN} |
WARNING | Manual close: YES Depends on: - HAProxy: Service is down |
HAProxy backend {#PXNAME}: Server is DOWN | Backend is not available. |
{TEMPLATE_NAME:haproxy.backend.status[{#PXNAME},{#SVNAME}].count(#5,"DOWN",eq)}=5 |
AVERAGE | |
HAProxy backend {#PXNAME}: Average response time is more than {$HAPROXY.BACK_RTIME.MAX.WARN} for 5m | Average backend response time (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_RTIME.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.backend.rtime[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.BACK_RTIME.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Number of responses with error is more than {$HAPROXY.BACK_ERESP.MAX.WARN} for 5m | Number of requests on backend, whose responses yielded an error, is more than {$HAPROXY.BACK_ERESP.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.backend.eresp.rate[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.BACK_ERESP.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Current number of requests unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN} for 5m | Current number of requests on backend unassigned in queue is more than {$HAPROXY.BACK_QCUR.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.backend.qcur[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.BACK_QCUR.MAX.WARN} |
WARNING | |
HAProxy backend {#PXNAME}: Average time spent in queue is more than {$HAPROXY.BACK_QTIME.MAX.WARN} for 5m | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.BACK_QTIME.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.backend.qtime[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.BACK_QTIME.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Session utilization is more than {$HAPROXY.FRONT_SUTIL.MAX.WARN}% for 5m | Alerting on this metric is essential to ensure your server has sufficient capacity to handle all concurrent sessions. Unlike requests, upon reaching the session limit HAProxy will deny additional clients until resource consumption drops. Furthermore, if you find your session usage percentage to be hovering above 80%, it could be time to either modify HAProxy's configuration to allow more sessions, or migrate your HAProxy server to a bigger box. |
{TEMPLATE_NAME:haproxy.frontend.sutil[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.FRONT_SUTIL.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN} for 5m | Number of request errors is more than {$HAPROXY.FRONT_EREQ.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.frontend.ereq.rate[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.FRONT_EREQ.MAX.WARN} |
WARNING | |
HAProxy frontend {#PXNAME}: Number of requests denied is more than {$HAPROXY.FRONT_DREQ.MAX.WARN} for 5m | Number of requests denied due to security concerns (ACL-restricted) is more than {$HAPROXY.FRONT_DREQ.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.frontend.dreq.rate[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.FRONT_DREQ.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Server is DOWN | Server is not available. |
{TEMPLATE_NAME:haproxy.server.status[{#PXNAME},{#SVNAME}].count(#5,"DOWN",eq)}=5 |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average response time is more than {$HAPROXY.SERVER_RTIME.MAX.WARN} for 5m | Average server response time (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_RTIME.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.server.rtime[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.SERVER_RTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Number of responses with error is more than {$HAPROXY.SERVER_ERESP.MAX.WARN} for 5m | Number of requests on server, whose responses yielded an error, is more than {$HAPROXY.SERVER_ERESP.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.server.eresp.rate[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.SERVER_ERESP.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN} for 5m | Current number of requests unassigned in queue is more than {$HAPROXY.SERVER_QCUR.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.server.qcur[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.SERVER_QCUR.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Average time spent in queue is more than {$HAPROXY.SERVER_QTIME.MAX.WARN} for 5m | Average time spent in queue (in ms) for the last 1,024 requests is more than {$HAPROXY.SERVER_QTIME.MAX.WARN}. |
{TEMPLATE_NAME:haproxy.server.qtime[{#PXNAME},{#SVNAME}].min(5m)}>{$HAPROXY.SERVER_QTIME.MAX.WARN} |
WARNING | |
HAProxy {#PXNAME} {#SVNAME}: Health check error | Please check the server for faults. |
`{TEMPLATE_NAME:haproxy.server.check_status[{#PXNAME},{#SVNAME}].regexp("(?:L[4-7]OK | ^$)",#3)} = 0` | WARNING |
Feedback
Please report any issues with the template at https://support.zabbix.com
You can also provide a feedback, discuss the template or ask for help with it at ZABBIX forums.