1 Функции макросов

Обзор

Функции макросов дают возможность индивидуализации значений макросов.

Иногда макрос может раскрыться в значение, с которым не всегда легко работать. Значение может быть длинным или содержать определённую подстроку, которая вас интересует и которую вы бы хотели извлечь. Это та задача, где функции макросов могут быть полезны.

Синтаксис функции макросов:

{<макрос>.<функция>(<параметры>)}

где:

  • <макрос> - настраиваемый макрос (например, {ITEM.VALUE} или {#LLD_МАКРОС})
  • <функция> - применяемая функция
  • <параметры> - список параметров функции, разделенных запятыми. Параметры необходимо заключать в кавычки, если они начинаются с '' '' (пробела), " или содержат ), ,.

Например:

{{TIME}.fmttime(формат,сдвиг_времени)}
       {{ITEM.VALUE}.regsub(шаблон, вывод)}
       {{#LLD_МАКРОС}.regsub(шаблон, вывод)}

Поддерживаемые функции макросов

ФУНКЦИЯ
Описание Параметры Поддерживается для
fmtnum (<цифры>)
Форматирование числа для управления количеством цифры выводимых после десятичной точки. цифры - количество цифр после десятичной точки. Конечные нули будут обрезаны. {ITEM.VALUE}
{ITEM.LASTVALUE}
Макросы выражений
fmttime (<формат>,<сдвиг_времени>)
Формат времени. формат - обязательный формат строки, совместимый с strftime функцией форматирования
сдвиг_времени - сдвиг времени применяемый к значению времени до форматирования; должен начинаться с
-<N><единица_времени> или +<N><единица_времени>, где
N - количество единиц времени для добавления или извлечения;
единица_времени - h (час), d (день), w (неделя), M (месяц) или y (год).
С Zabbix 5.4, параметр сдвиг_времени поддерживает многоэтапные операции со временем и может включать /<единица_времени> для сдвига к началу единицы времени (/d - полночь, /w - 1-ый день недели (Понедельник), /M - 1-ый день месяца и т.д.). Примеры:
-1w - ровно 7 дней назад;
-1w/w - Понедельник предыдущей недели;
-1w/w+1d - Вторник предыдущей недели.
Обратите внимание, что операции времени вычисляются слева направо, без учета приоритетов. Например, -1M/d+1h/w будет проанализирован как ((-1M/d)+1h)/w.
{TIME}
iregsub (<шаблон>,<вывод>)
Извлечение подстроки совпадением с регулярным выражением (без учета регистра). шаблон - регулярное выражение для поиска совпадения
вывод - опции вывода. Для захвата групп поддерживаются местозаменители \1 - \9 (заменитель). \0 вернёт соответствующий текст.
{ITEM.VALUE}
{ITEM.LASTVALUE}
Макросы низкоуровневого обнаружения (за исключением фильтра низкоуровневого обнаружения)
regsub (<шаблон>,<вывод>)
Извлечение подстроки совпадением с регулярным выражением (с учетом регистра). шаблон - регулярное выражение для поиска совпадения
вывод - опции вывода. Для захвата групп поддерживаются местозаменители \1 - \9 (заменитель). \0 вернёт соответствующий текст.
{ITEM.VALUE}
{ITEM.LASTVALUE}
Макросы низкоуровневого обнаружения (за исключением фильтра низкоуровневого обнаружения)

Если функция используется в поддерживаемых местах, но применён макрос, который не поддерживает функции макросов, тогда макрос раскроется в 'НЕИЗВЕСТНО'.

Если шаблон не соответствует регулярному выражению, тогда макрос раскрывается в 'НЕИЗВЕСТНО' (за исключением макросов низкоуровневого обнаружения, где в этом случае функция будет проигнорирована и макрос останется нераскрытым)

Если функция макросов применяется в макросе в местах, которые не поддерживают функции макросов, тогда функция будет игнорироваться.

Примеры

Способы использования функции макросов для индивидуализации значений проиллюстрированы следующими примерами полученных значений:

Полученное значение Макрос Вывод
24.3413523 {{ITEM.VALUE}.fmtnum(2)} 24.34
24.3413523 {{ITEM.VALUE}.fmtnum(0)} 24
12:36:01 {{TIME}.fmttime(%B)} October
12:36:01 {{TIME}.fmttime(%d %B,-1M/M)} 1 September
123Log line {{ITEM.VALUE}.regsub(^[0-9]+, Problem)} Problem
123 Log line {{ITEM.VALUE}.regsub("^([0-9]+)", "Problem")} Problem
123 Log line {{ITEM.VALUE}.regsub("^([0-9]+)", Problem ID: \1)} Problem ID: 123
Log line {{ITEM.VALUE}.regsub(".*", "Problem ID: \1")} ''Problem ID: ''
MySQL crashed errno 123 {{ITEM.VALUE}.regsub("^(\w+).*?([0-9]+)", " Problem ID: \1_\2 ")} '' Problem ID: MySQL_123 ''
123 Log line {{ITEM.VALUE}.regsub("([1-9]+", "Problem ID: \1")} *НЕИЗВЕСТНО* (ошибочное регулярное выражение)
customername_1 {{#IFALIAS}.regsub("(.*)_([0-9]+)", \1)} customername
customername_1 {{#IFALIAS}.regsub("(.*)_([0-9]+)", \2)} 1
customername_1 {{#IFALIAS}.regsub("(.*)_([0-9]+", \1)} {{#IFALIAS}.regsub("(.*)_([0-9]+", \1)} (ошибочное регулярное выражение)
customername_1 {$MACRO:"{{#IFALIAS}.regsub(\"(.*)_([0-9]+)\", \1)}"} {$MACRO:"customername"}
customername_1 {$MACRO:"{{#IFALIAS}.regsub(\"(.*)_([0-9]+)\", \2)}"} {$MACRO:"1"}
customername_1 {$MACRO:"{{#IFALIAS}.regsub(\"(.*)_([0-9]+\", \1)}"} {$MACRO:"{{#M}.regsub(\"(.*)_([0-9]+\", \1)}"} (ошибочное регулярное выражение)
customername_1 "{$MACRO:\"{{#IFALIAS}.regsub(\\"(.*)_([0-9]+)\\", \1)}\"}" "{$MACRO:\"customername\"}"
customername_1 "{$MACRO:\"{{#IFALIAS}.regsub(\\"(.*)_([0-9]+)\\", \2)}\"}" "{$MACRO:\"1\"}")
customername_1 "{$MACRO:\"{{#IFALIAS}.regsub(\\"(.*)_([0-9]+\\", \1)}\"}" "{$MACRO:\"{{#IFALIAS}.regsub(\\"(.*)_([0-9]+\\", \1)}\"}") (ошибочное регулярное выражение)
Просмотр полных значений элемента данных

Длинные значения раскрытых макросов {ITEM.VALUE} и {ITEM.LASTVALUE} обрезаются до 20 символов. Для просмотра полных значений этих макросов вы можете использовать функции макросов, например:

{{ITEM.VALUE}.regsub("(.*)", \1)}
{{ITEM.LASTVALUE}.regsub("(.*)", \1)}