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:

  1. El server abre una conexión TCP
  2. El server envía <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"agent.ping","timeout":3}]}
  3. El agent lee la solicitud y responde con <HEADER><DATALEN>{"version":"8.0.0","variant":2,"data":[{"value":1}]}
  4. El server procesa los datos para obtener el valor, '1' en nuestro caso
  5. Se cierra la conexión TCP

Para items no compatibles:

  1. El server abre una conexión TCP
  2. El server envía <HEADER><DATALEN>{"request":"passive checks","data":[{"key":"vfs.fs.size[/nono]","timeout":3}]}
  3. El agent lee la solicitud y responde con <HEADER><DATALEN>{"version":"8.0.0","variant":2,"data":[{"error":"Unsupported item key."}]}
  4. El server procesa los datos, cambia el estado del item a no compatible con el mensaje de error especificado
  5. 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:

  1. El agent abre una conexión TCP
  2. El agent solicita la lista de checks
  3. El server responde con una lista de items y comandos remotos a ejecutar
  4. El agent analiza la respuesta
  5. La conexión TCP se cierra
  6. 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 agent data
data array de objetos Valores de los item.
id number El identificador del valor (contador incremental utilizado para comprobar valores duplicados en caso de problemas de red).
itemid number 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 La marca de tiempo del valor (segundos desde Epoch).
ns number 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 Identificador de sesión único generado cada vez que se inicia el agent.
host string Nombre del host.
version string El número de versión del agent.
variant number 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 success | failed
info string 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:

  1. El agent abre una conexión TCP
  2. El agent envía una lista de valores
  3. El server procesa los datos y envía el estado de vuelta
  4. 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.