2 Comprobaciones pasivas y activas del agente
Descripción general
Esta sección proporciona detalles sobre las comprobaciones pasivas y activas realizadas por el agente Zabbix y el agente Zabbix 2.
Zabbix utiliza un protocolo de comunicación basado en JSON para comunicarse con los agentes.
Los protocolos del agente Zabbix y del agente Zabbix 2 se han unificado desde Zabbix 7.0. La diferencia entre las solicitudes/respuestas del agente Zabbix y del agente Zabbix 2 se expresa mediante el valor de la etiqueta "variant".
Comprobaciones pasivas
Una comprobación pasiva es una simple solicitud de datos. El server o proxy de Zabbix solicita algunos datos (por ejemplo, la carga de CPU) y el agent de Zabbix devuelve el resultado al server.
Las comprobaciones pasivas se ejecutan de forma asíncrona: no es necesario recibir la respuesta a una solicitud antes de iniciar otras comprobaciones. La resolución DNS también es asíncrona.
El poller del agent intentará conectarse a todas las direcciones devueltas por la búsqueda DNS. Esto garantiza que, si una dirección IP no es accesible, el poller probará la siguiente dirección disponible, aumentando la probabilidad de una conexión correcta. Esta mejora se aplica tanto al server como al proxy de Zabbix.
La concurrencia máxima de las comprobaciones asíncronas es 1000 (definida por MaxConcurrentChecksPerPoller).
El número de pollers asíncronos del agent se define mediante el parámetro StartAgentPollers.
Solicitud del server
Para la definición de la longitud del encabezado y de los datos, consulte los detalles del protocolo.
{
"request": "passive checks",
"data": [
{
"key": "agent.version",
"timeout": 3
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| request | string | yes | "passive checks" |
|
| data | array of object | yes | Elemento de comprobación pasiva. | |
| key | string | yes | Clave del item con macros expandidas. | |
| timeout | number | yes | Tiempo de espera de comunicación. | |
Respuesta del agent
{
"version": "8.0.0",
"variant": 2,
"data": [
{
"value": "8.0.0"
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| version | string | yes | El número de versión del agent. | |
| variant | number | yes | La variante del agent (1 - Zabbix agent, 2 - Zabbix agent 2). | |
| data | array of object | yes | Contiene el resultado de la comprobación. | |
| value | string | no | El valor del item si la comprobación se realizó correctamente. | |
| error | string | no | El mensaje de error si la comprobación no se realizó correctamente. | |
Por ejemplo, para items compatibles:
- El server abre una conexión TCP
- El server envía <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"agent.ping","timeout":3}]}
- El agent lee la solicitud y responde con <HEADER><DATALEN>{"version":"8.0.0","variant":2,"data":[{"value":1}]}
- El server procesa los datos para obtener el valor, '1' en nuestro caso
- Se cierra la conexión TCP
Para items no compatibles:
- El server abre una conexión TCP
- El server envía <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"vfs.fs.size[/nono]","timeout":3}]}
- El agent lee la solicitud y responde con <HEADER><DATALEN>{"version":"8.0.0","variant":2,"data":[{"error":"Unsupported item key."}]}
- El server procesa los datos, cambia el estado del item a no compatible con el mensaje de error especificado
- Se cierra la conexión TCP
Conmutación por error al protocolo antiguo
Para asegurarse de que el servidor o proxy de Zabbix pueda trabajar con agentes de versiones anteriores a la 7.2, que utilizan el protocolo en texto plano, se implementa una conmutación por error al protocolo antiguo.
Las comprobaciones pasivas se realizan utilizando el protocolo JSON (7.0 y posteriores) después de reiniciar o cuando se cambia la configuración de la interfaz. Si no se recibe un JSON válido en respuesta (el agente envió "ZBX_NOTSUPPORTED"), Zabbix almacenará en caché la interfaz como protocolo antiguo y reintentará la comprobación enviando solo la clave de la métrica.
Tenga en cuenta que cada hora el servidor/proxy de Zabbix volverá a intentar trabajar con el nuevo protocolo en todas las interfaces, volviendo al protocolo antiguo si es necesario.
Comprobaciones activas
Las comprobaciones activas requieren un procesamiento más complejo. El agent primero debe recuperar del server/proxy una lista de items y/o comandos remotos para su procesamiento independiente.
Los servers/proxies de los que se obtienen las comprobaciones activas se enumeran en el parámetro 'ServerActive' del archivo de configuración del agent. La frecuencia con la que se solicitan estas comprobaciones se establece mediante el parámetro 'RefreshActiveChecks' en el mismo archivo de configuración. Sin embargo, si la actualización de las comprobaciones activas falla, se reintenta después de 60 segundos codificados de forma fija.
Desde Zabbix 6.4 el agente (en modo activo) ya no recibe del servidor/proxy una copia completa de la configuración cada dos minutos (por defecto). En su lugar, para disminuir el tráfico de red y el uso de recursos, se realiza una sincronización incremental de la configuración cada 5 segundos (por defecto), en la que el servidor/proxy proporciona una copia completa de la configuración solo si el agente aún no la ha recibido, o si algo ha cambiado en la configuración del equipo, macros globales o expresiones regulares globales.
El agente luego envía periódicamente los nuevos valores al/los servidor(es). Si el agente recibió algún comando remoto para ejecutar, el resultado de la ejecución también se enviará. Tenga en cuenta que la ejecución de comandos remotos en un agente activo es compatible desde Zabbix agent 7.0.
Si un agente está detrás de un firewall, podría considerar usar solo comprobaciones activas porque en este caso no necesitaría modificar el firewall para permitir conexiones entrantes iniciales.
Obtención de la lista de items
Solicitud del agent
La solicitud de active checks se utiliza para obtener los active checks que deben ser procesados por el agent.
Esta solicitud es enviada por el agent al iniciarse y luego en intervalos de RefreshActiveChecks.
{
"request": "active checks",
"host": "Zabbix server",
"host_metadata": "mysql,nginx",
"interface": "zabbix.server.lan",
"ip": "159.168.1.1",
"port": 12050,
"version": "8.0.0",
"variant": 2,
"config_revision": 1,
"session": "e3dcbd9ace2c9694e1d7bbd030eeef6e"
}
| Field | Type | Mandatory | Value |
|---|---|---|---|
| request | string | yes | active checks |
| host | string | yes | Nombre del host. |
| host_metadata | string | no | El parámetro de configuración HostMetadata o el valor de la métrica HostMetadataItem. |
| interface | string | no | El parámetro de configuración HostInterface o el valor de la métrica HostInterfaceItem. |
| ip | string | no | La primera IP del parámetro de configuración ListenIP, si está definido. |
| port | number | no | El valor del parámetro de configuración ListenPort, si está definido y no es el puerto de escucha predeterminado del agent. |
| version | string | yes | El número de versión del agent. |
| variant | number | yes | La variante del agent (1 - Zabbix agent, 2 - Zabbix agent 2). |
| config_revision | number | no | Identificador de configuración para sincronización incremental de configuración. |
| session | string | no | Identificador de sesión para sincronización incremental de configuración. |
Respuesta del server
La respuesta de active checks es enviada por el server al agent después de procesar la solicitud de active checks.
{
"response": "success",
"config_revision": 2,
"data": [
{
"key": "system.uptime",
"itemid": 1234,
"delay": "10s",
"lastlogsize": 0,
"mtime": 0
},
{
"key": "agent.version",
"itemid": 5678,
"delay": "10m",
"lastlogsize": 0,
"mtime": 0,
"timeout": "30s"
}
],
"commands": [
{
"command": "df -h --output=source,size / | awk 'NR>1 {print $2}'",
"id": 1324,
"wait": 1
}
]
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| response | string | yes | success | failed |
|
| info | string | no | Información de error en caso de fallo. | |
| data | array of objects | no | Items de active check. Se omite si la configuración del host no ha cambiado. | |
| key | string | no | Clave del item con macros expandidas. | |
| itemid | number | no | Identificador del item. | |
| delay | string | no | Intervalo de actualización del item. Los intervalos flexibles/de programación son compatibles tanto con Zabbix agent como con Zabbix agent 2 desde Zabbix 7.0. |
|
| lastlogsize | number | no | lastlogsize del item. | |
| mtime | number | no | mtime del item. | |
| timeout | string | no | Tiempo de espera del item. | |
| refresh_unsupported | number | no | Intervalo de actualización de items no compatibles. | |
| regexp | array of objects | no | Expresiones regulares globales. | |
| name | string | no | Nombre de la expresión regular global. | |
| expression | string | no | Expresión regular global. | |
| expression_type | number | no | Tipo de expresión regular global. | |
| exp_delimiter | string | no | Delimitador de la expresión regular global. | |
| case_sensitive | number | no | Configuración de sensibilidad a mayúsculas y minúsculas de la expresión regular global. | |
| commands | array of objects | no | Comandos remotos a ejecutar. Se incluyen si la ejecución de comandos remotos ha sido activada por una operación de action o por la ejecución manual de un script. Tenga en cuenta que la ejecución de comandos remotos en un agent activo es compatible desde Zabbix agent 7.0. Los agents activos anteriores ignorarán cualquier comando remoto incluido en la respuesta del server de active checks. | |
| command | string | no | Comando remoto. | |
| id | number | no | Identificador del comando remoto. | |
| wait | number | no | Modo de ejecución del comando remoto ("0" (nowait) para comandos de operaciones de action; "1" (wait) para comandos de ejecución manual de script). | |
| timeout | number | no | Tiempo de espera de ejecución del comando remoto en la configuración de server/proxy. | |
| config_revision | number | no | Identificador de configuración para sincronización incremental de configuración. Se omite si la configuración del host no ha cambiado. Se incrementa si la configuración del host cambia. | |
El server debe responder con success.
Por ejemplo:
- El agent abre una conexión TCP
- El agent solicita la lista de checks
- El server responde con una lista de items y comandos remotos a ejecutar
- El agent analiza la respuesta
- La conexión TCP se cierra
- El agent inicia la recopilación periódica de datos y ejecuta comandos remotos (compatible desde Zabbix agent 7.0)
Tenga en cuenta que los datos de configuración (sensibles) pueden quedar disponibles para terceros que tengan acceso al puerto trapper del Zabbix server al usar un active check. Esto es posible porque cualquiera puede hacerse pasar por un agent activo y solicitar datos de configuración de items; la autenticación no tiene lugar a menos que use opciones de encryption.
Envío de datos recopilados
El agent envía
La solicitud de datos del agent contiene los valores de los item recopilados y los valores de los comandos remotos ejecutados (si los hay).
{
"request": "agent data",
"data": [
{
"id": 1,
"itemid": 5678,
"value": "7.0.0",
"clock": 1712830783,
"ns": 76808644
},
{
"id": 2,
"itemid": 1234,
"value": "69672",
"clock": 1712830783,
"ns": 77053975
}
],
"commands": [
{
"id": 1324,
"value": "16G"
}
],
"session": "8495cd52070e6ca52b371f29c8574165",
"host": "Zabbix server",
"version": "8.0.0",
"variant": 2
}
| Campo | Tipo | Obligatorio | Valor | |
|---|---|---|---|---|
| request | string | sí | agent data |
|
| data | array de objetos | sí | Valores de los item. | |
| id | number | sí | El identificador del valor (contador incremental utilizado para comprobar valores duplicados en caso de problemas de red). | |
| itemid | number | sí | El identificador del item. | |
| value | string | no | El valor del item. | |
| lastlogsize | number | no | El lastlogsize del item. | |
| mtime | number | no | El mtime del item. | |
| state | number | no | El state del item. | |
| source | string | no | El source del valor del event log. | |
| eventid | number | no | El eventid del valor del event log. | |
| severity | number | no | El severity del valor del event log. | |
| timestamp | number | no | El timestamp del valor del event log. | |
| clock | number | sí | La marca de tiempo del valor (segundos desde Epoch). | |
| ns | number | sí | La marca de tiempo del valor en nanosegundos. | |
| commands | array de objetos | no | Resultado de la ejecución de comandos remotos. Tenga en cuenta que la ejecución de comandos remotos en un agent activo es compatible desde Zabbix agent 7.0. Los agent activos más antiguos ignorarán cualquier comando remoto incluido en la respuesta del server de comprobaciones activas. | |
| id | number | no | Identificador del comando remoto. | |
| value | string | no | Resultado de la ejecución del comando remoto si la ejecución fue exitosa. | |
| error | string | no | Mensaje de error de ejecución del comando remoto si la ejecución falló. | |
| session | string | sí | Identificador de sesión único generado cada vez que se inicia el agent. | |
| host | string | sí | Nombre del host. | |
| version | string | sí | El número de versión del agent. | |
| variant | number | sí | La variante del agent (1 - Zabbix agent, 2 - Zabbix agent 2). | |
Se asigna un ID virtual a cada valor. El ID de valor es un contador ascendente simple, único dentro de una sesión de datos (identificada por el token de sesión). Este ID se utiliza para descartar valores duplicados que puedan enviarse en entornos con mala conectividad.
Respuesta del server
La respuesta de datos del agent es enviada por el server de vuelta al agent después de procesar la solicitud de datos del agent.
{
"response": "success",
"info": "processed: 2; failed: 0; total: 2; seconds spent: 0.003534"
}
| Campo | Tipo | Obligatorio | Valor |
|---|---|---|---|
| response | string | sí | success | failed |
| info | string | sí | Resultados del procesamiento de los item. |
Si el envío de algunos valores falla en el server (por ejemplo, porque el host o el item han sido deshabilitados o eliminados), el agent no volverá a intentar enviar esos valores.
Por ejemplo:
- El agent abre una conexión TCP
- El agent envía una lista de valores
- El server procesa los datos y envía el estado de vuelta
- La conexión TCP se cierra
El mensaje de error se recortará a 2048 símbolos en el lado del server.
Mensaje de heartbeat
Agent envía
El mensaje de heartbeat es enviado por un agent activo al server/proxy de Zabbix cada HeartbeatFrequency segundos (configurado en el archivo de configuración de Zabbix agent/agent 2).
Se utiliza para supervisar la disponibilidad de las comprobaciones activas.
{
"request": "active check heartbeat",
"host": "Zabbix server",
"heartbeat_freq": 60,
"version": "8.0.0",
"variant": 2
}
| Field | Type | Mandatory | Value |
|---|---|---|---|
| request | string | yes | active check heartbeat |
| host | string | yes | El nombre del host. |
| heartbeat_freq | number | yes | La frecuencia de heartbeat del agent (parámetro de configuración HeartbeatFrequency). |
| version | string | yes | El número de versión del agent. |
| variant | number | yes | La variante del agent (1 - Zabbix agent, 2 - Zabbix agent 2). |
Respuesta de redirección
Cuando un host ha sido reasignado, el server puede indicar al agent que redirija su heartbeat (y las comprobaciones activas posteriores) a otra instancia de proxy o server.
{
"response": "failed",
"redirect": {
"revision": 2,
"address": "192.0.2.1:10055"
}
}
| Field | Type | Mandatory | Value | |
|---|---|---|---|---|
| response | string | yes | success | failed |
|
| redirect | object | yes | Instrucciones de redirección. | |
| revision | number | yes | Identificador de la revisión de configuración. | |
| address | string | yes | Dirección de destino del server/proxy. | |
Protocolo XML antiguo
Zabbix aceptará hasta 16 MB de datos XML codificados en Base64, pero un único valor decodificado no debe superar los 64 KB, de lo contrario se truncará a 64 KB durante la decodificación.