Функции макросов дают возможность индивидуализации значений макросов.
Иногда макрос может раскрыться в значение, с которым не всегда легко работать. Значение может быть длинным или содержать определённую подстроку, которая вас интересует и которую вы бы хотели извлечь. Это та задача, где функции макросов могут быть полезны.
Синтаксис функции макросов:
где:
"
или содержат )
, ,
.Например:
{{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)}