#3 Macros de usuario con contexto

Visión general

Se puede usar un contexto opcional en usuario macros, lo que permite anular el valor predeterminado con uno específico del contexto.

El contexto se agrega al nombre de la macro; la sintaxis depende de si el contexto es un valor de texto estático:

{$MACRO:"texto estático"}

o una expresión regular:

{$MACRO:regex:"expresión regular"}

Tenga en cuenta que una macro con contexto de expresión regular solo se puede definir en configuración de macros de usuario. Si el prefijo regex: se usa en otro lugar como contexto de macro de usuario, como en una expresión de activación, se tratará como contexto estático.

Las citas contextuales son opcionales (ver también important notas).

Ejemplos de macro contexto:

Ejemplo Descripción
{$LOW_SPACE_LIMIT} Macro de usuario sin contexto.
{$LOW_SPACE_LIMIT:/tmp} Macro de usuario con contexto (cadena estática).
{$LOW_SPACE_LIMIT:regex:"^/tmp$"} Macro de usuario con contexto (expresión regular). Igual que {$LOW_SPACE_LIMIT:/tmp}.
{$LOW_SPACE_LIMIT:regex:"^/var/log/.*$"} Macro de usuario con contexto (expresión regular). Coincide con todas las cadenas con el prefijo /var/log/.

Casos de uso

Se pueden definir macros de usuario con contexto para lograr umbrales más flexibles en expresiones de activación (según los valores recuperados por la detección de bajo nivel). Por ejemplo, puede definir las siguientes macros:

  • {$LOW_SPACE_LIMIT} = 10
  • {$LOW_SPACE_LIMIT:/home} = 20
  • {$LOW_SPACE_LIMIT:regex:"^/[a-z]+$"} = 30

Luego, se puede utilizar una macro de detección de bajo nivel como contexto de macro en un prototipo de iniciador para la detección de sistemas de archivos montados:

last(/host/vfs.fs.size[{#FSNAME},pfree])<{$LOW_SPACE_LIMIT:"{#FSNAME}"}

Después de la detección, se aplicarán diferentes umbrales de espacio reducido en los iniciadores según los puntos de montaje o los tipos de sistemas de archivos detectados. Se generarán eventos problemáticos si:

  • La carpeta /home tiene menos del 20 % de espacio libre en disco
  • Las carpetas que coinciden con el patrón de expresiones regulares (como /etc, /tmp o /var) tienen menos del 30 % de espacio libre en disco
  • Las carpetas que no coinciden con el patrón de expresiones regulares y no son /home tienen menos del 10 % de espacio libre en disco

Notas importantes

  • Si existe más de una macro de usuario con contexto, Zabbix intentará haga coincidir las macros de contexto simples primero y luego las macros de contexto con expresiones regulares en un orden indefinido.

::: nota de advertencia No cree macros de contexto diferentes que coincidan con el misma cadena para evitar un comportamiento indefinido. :::

  • Si una macro con su contexto no se encuentra en el host, las plantillas vinculadas o globalmente, entonces se busca la macro sin contexto.
  • Solo se admiten macros de descubrimiento de bajo nivel en el contexto. Ningún otras macros se ignoran y se tratan como texto sin formato.

Técnicamente, el contexto macro se especifica usando reglas similares a item key parámetros, excepto que el contexto macro es no se analiza como varios parámetros si hay un carácter ,:

  • El macro contexto debe citarse con " si el contexto contiene un } o comienza con un carácter ". Comillas dentro de comillas El contexto debe escaparse con el carácter \.
  • El carácter \ en sí mismo no se escapa, lo que significa que es imposible tener un contexto citado que termine con el carácter \ - la macro {$MACRO:"a:\b\c\"} no es válido.
  • Los espacios iniciales en contexto se ignoran, los espacios finales se no:
    • Por ejemplo, {$MACRO:A} es lo mismo que {$MACRO:A}, pero no {$MACRO:A}.
  • Todos los espacios antes de las comillas iniciales y después de las comillas finales son ignorado, pero todos los espacios dentro de las comillas no son:
    • Macros {$MACRO:"A"}, {$MACRO: "A"}, {$MACRO:"A" } y {$MACRO: "A" } son iguales, pero las macros {$MACRO:"A"} y {$MACRO:" A "} no son.

Las siguientes macros son todas equivalentes, porque tienen el mismo contexto: {$MACRO:A}, {$MACRO: A} y {$MACRO:"A"}. esto es en contraste con claves de elemento, donde 'clave[a]', 'clave[ a]' y 'clave["a"]' son las mismo semánticamente, pero diferente para propósitos de unicidad.