Используемые в триггерах выражения являются очень гибкими. Вы можете использовать их для создания сложных логических тестов с учетом статистики по мониторингу.
Простое выражение использует функцию, которая применяется к элементу данных с некоторыми параметрами. Функция возвращает результат, который сравнивается с порогом, используя оператор и константу.
Синтаксис простого полезного выражения: функция(/узел сети/ключ,параметр)<оператор><константа>
.
Например:
сработает, если количество полученных байт за последние пять минут всегда превышает 100 килобайт.
С функциональной точки зрения существует два типа выражений триггеров, хоть они и имеют абсолютно одинаковый синтаксис:
Когда задается только выражение проблемы, это выражение будет использоваться в качестве порога как проблемы, так и восстановления проблемы. Как только выражение проблемы вычисляется в значение ИСТИНА, возникает проблема. Как только выражение проблемы вычисляется в значение ЛОЖЬ, проблема считается решённой.
Если задаются оба выражения, как проблемы, так и дополнительного выражения восстановления, решение проблемы становится более сложным: не только выражение проблемы должно стать ЛОЖЬ, но также и выражение восстановления должно стать ИСТИН. Такой подход полезен для создания гистерезиса и помогает избежать частых переключений триггера (из / в состояние ПРОБЛЕМЫ и обратно).
Функции позволяют обсчитывать собранные значения (вычислять среднее, минимальное, максимальное, сумму), искать строки, ссылаться на текущее время, принимать во внимание и другие факторы.
Имеется полный список поддерживаемых функций.
Обычно функции возвращают числовые значения для последующего сравнения. При возвращении строк можно выполнять сравнения при помощи операторов = и <> (смотрите пример).
Параметры функций позволяют указать:
Узел сети и ключ элемента данных можно указать в виде /узел сети/ключ
. Элемент данных, на который ссылается функция, должен быть в поддерживаемом состоянии (за исключением функции nodata(), которая вычисляется также по неподдерживаемым элементам данных).
В то время как в триггерах другие выражения триггеров в качестве параметров функции ограничены функциями, не связанными с историей, это ограничение не применяется к вычисляемым элементам данных.
Параметры, которые зависят от используемой функции, помещаются после ключа элемента данных и отделяются от него запятой. Смотрите полный список этих параметров по поддерживаемым функциям.
Большинство числовых функций принимают время в качестве параметра. Чтобы указать время, вы можете использовать секунды или суффиксы времени. Параметр, которому предшествует символ решётки, имеет другое значение:
Выражение | Описание |
---|---|
sum(/узел сети/ключ,10m) | Сумма значений за последние 10 минут. |
sum(/узел сети/ключ,#10) | Сумма последних десяти значений. |
В случае с функцией last параметры с символом решётки имеют другой смысл - они обозначают N-ое предыдущее значение, таким образом, с учетом заданных значений 3, 7, 2, 6, 5 (от самого последнего к наименее последнему значению):
last(/узел сети/ключ,#2)
вернёт '7'last(/узел сети/ключ,#5)
вернёт '5'В качестве параметра функции поддерживается опциональный сдвиг времени со временем или количеством значений. Этот параметр позволяет ссылаться на данные из периода времени в прошлом.
Сдвиг времени начинается с now
- указывает текущее время, за которым следует +N<единица времени>
или -N<единица времени>
- для добавления или вычитания N-го количества единиц времени.
Например, avg(/узел сети/ключ,1h:now-1d)
вернет среднее значение за час днем ранее.
Сдвиг времени, указанный в месяцах (M) и годах (y), поддерживается только для функций динамики изменений. Остальные функции поддерживают секунды (s), минуты (m), часы (h), дни (d) и недели (w).
Сдвиг времени с абсолютными периодами времени
Абсолютные периоды времени поддерживаются в параметре сдвига времени, например, с полуночи до полуночи для дня, понедельник-воскресенье для недели, первый - последний день месяца для месяца.
Сдвиг времени по абсолютным периодам времени начинается с now
- указывает текущее время, за которым следует любое количество временных операций: /<единица времени>
- определяет начало и конец единицы времени, например, с полуночи до полуночи для дня, +N<единица времени>
или -N<единица времени>
- для добавления или вычитания N-го количества единиц времени.
Обратите внимание, что значение сдвига времени может быть больше или равно 0, тогда как минимальный период времени равен значению 1.
Параметр | Описание |
---|---|
1d:now/d | Вчера |
1d:now/d+1d | Сегодня |
2d:now/d+1d | Последние 2 дня |
1w:now/w | Последняя неделя |
1w:now/w+1w | Текущая неделя |
Параметры функций могут содержать другие выражения в соответствии со следующим синтаксисом:
Обратите внимание, что другие выражения нельзя использовать, если функция ссылается на историю элемента данных. Например, следующий синтаксис не разрешён:
min(/узел сети/ключ,#5*10)
Следующие операторы поддерживаются триггерами (представлены по убыванию приоритета выполнения):
Приоритет | Оператор | Определение | Заметки по неизвестным значениям | Принудительное преобразование операнда в дробное число 1 |
---|---|---|---|---|
1 | - | Унарный минус | -Неизвестно → Неизвестно | Да |
2 | not | Логическое НЕ | not Неизвестно → Неизвестно | Да |
3 | * | Умножение | 0 * Неизвестно → Неизвестно (да, Неизвестно, не 0 - чтобы не потерять Неизвестно в арифметических операциях) 1.2 * Неизвестно → Неизвестно |
Да |
/ | Деление | Неизвестно / 0 → ошибка Неизвестно / 1.2 → Неизвестно 0.0 / Неизвестно → Неизвестно |
Да | |
4 | + | Арифметический плюс | 1.2 + Неизвестно → Неизвестно | Да |
- | Арифметический минус | 1.2 - Неизвестно → Неизвестно | Да | |
5 | < | Меньше чем. Этот оператор можно представить в виде: A<B ⇔ (A<B-0.000001) |
1.2 < Неизвестно → Неизвестно | Да |
<= | Меньше чем или равно. Этот оператор можно представить в виде: A<=B ⇔ (A≤B+0.000001) |
Неизвестно <= Неизвестно → Неизвестно | Да | |
> | Больше чем. Этот оператор можно представить в виде: A>B ⇔ (A>B+0.000001) |
Да | ||
>= | Больше чем или равно. Этот оператор можно представить в виде: A>=B ⇔ (A≥B-0.000001) |
Да | ||
6 | = | Равно. Этот оператор можно представить в виде: A=B ⇔ (A≥B-0.000001) и (A≤B+0.000001) |
Нет 1 | |
<> | Не равно. Этот оператор можно представить в виде: A<>B ⇔ (A<B-0.000001) или (A>B+0.000001) |
Нет 1 | ||
7 | and | Логическое И | 0 and Неизвестно → 0 1 and Неизвестно → Неизвестно Неизвестно and Неизвестно → Неизвестно |
Да |
8 | or | Логическое ИЛИ | 1 or Неизвестно → 1 0 or Неизвестно → Неизвестно Неизвестно or Неизвестно → Неизвестно |
Да |
1 Строковый операнд по прежнему приводится к числовому значению, если:
(Если приведение завершается с ошибкой - числовой операнд приводится к строковому операнду и оба операнда сравниваются как строковые значения.)
Операторы not, and and or зависят от регистра и должны быть в нижнем регистре. Они также должны быть окружены символами пробелов или круглыми скобками.
Все операторы, кроме унарных - и not, имеют ассоциативность слева направо. Унарные - и not не ассоциативны (имеется в виду, что нужно использовать -(-1) и not (not 1) вместо --1 и not not 1).
Результат вычисления:
Значения, которые необходимы для вычисления триггеров, кэшируются Zabbix сервером. По этой причине такое вычисление триггеров приводит к более высокой нагрузке на базу данных на некоторое время после перезапуска сервера. Кэш значений не очищается, когда значения истории элементов данных удаляются (либо вручную, либо при помощи автоматической очистки истории), поэтому сервер будет использовать кэшированные значения пока они не станут старше, чем периоды времени, заданные в функциях триггеров, либо пока сервер не будет перезапущен.
Высокая загрузка процессора на сервере Zabbix.
Используя функцию 'last()', мы ссылаемся на самое последнее значение. '/Zabbix server/system.cpu.load[all,avg1]' представляет короткое имя наблюдаемого параметра. Эта строка указывает, что сервер - 'Zabbix server' и наблюдаемый ключ - 'system.cpu.load[all,avg1]'. И, наконец, '>5' означает, что триггер будет переходить в состояние ПРОБЛЕМА всякий раз, когда самое последнее измерение загрузки процессора на сервере Zabbix server будет превышать 5.
www.example.com перегружен
last(/www.example.com/system.cpu.load[all,avg1])>5 or min(/www.example.com/system.cpu.load[all,avg1],10m)>2
Это выражение будет истинным, когда либо текущая загрузка процессора станет более 5, либо загрузка процессора больше значения 2 в течение последних 10 минут.
/etc/passwd был изменён.
(last(/www.example.com/vfs.file.cksum[/etc/passwd],#1)<>last(/www.example.com/vfs.file.cksum[/etc/passwd],#2))=1
Это выражение будет истинным, когда предыдущее значение контрольной суммы файла /etc/passwd отличается от самого нового значения.
Аналогичные выражения могут быть полезны для мониторинга изменений в важных файлах, таких как /etc/passwd, /etc/inetd.conf, /kernel и других.
Кто-то в данный момент скачивает большой файл из Интернет
Используется функция min:
Это выражение будет истинным, когда количество полученных байт на eth0 превышает 100 КБ за последних 5 минут.
Оба узла кластера SMTP серверов недоступны
Обратите внимание на то, что в выражении используются два разных узла сети:
last(/smtp1.example.com/net.tcp.service[smtp])=0 and last(/smtp2.example.com/net.tcp.service[smtp])=0
Это выражение будет истинным, когда оба SMTP сервера недоступны - и на smtp1.example.com, и на smtp2.example.com.
Zabbix агент нуждается в обновлении
Используется функция find():
Это выражение будет истинным, когда версия Zabbix агента содержит в себе 'beta8'.
Сервер недоступен
Это выражение будет истинным, если узел сети "example.example.com" недоступен более 5 раз за последние 30 минут.
Нет данных за последние 3 минуты
Используется функцию nodata():
Для того, чтобы этот триггер заработал, элемент данных ‘tick’ должен быть определён как элемент данных с типом Zabbix траппер. Узел сети должен периодически отправлять данные этому элементу данных, используя zabbix_sender. Если никаких данных не было получено за последние 180 секунд, значение триггера станет ПРОБЛЕМА.
Обратите внимание, что 'nodata' можно использовать с любым типом элементов данных.
Активность CPU в ночное время
Используется функция time():
min(/Zabbix server/system.cpu.load[all,avg1],5m)>2 and time()>000000 and time()<060000
Триггер может изменить свое состояние в ПРОБЛЕМА только в ночное время (00:00 - 06:00).
Активность CPU в любое время с исключением.
Используется функция time() и оператор not:
min(/zabbix/system.cpu.load[all,avg1],5m)>2 and not (dayofweek()=7 and time()>230000) and not (dayofweek()=1 and time()<010000)
Триггер может изменить свое состояние на Проблема в любое время, за исключением интервала в 2 часа при изменении недели (Воскресенье, 23:00 - Понедельник, 01:00).
Проверка синхронизации времени на клиенте со временем на Zabbix сервере
Используется функция fuzzytime():
fuzzytime(/MySQL_DB/system.localtime,10s)=0
Триггер изменит состояние на проблему тогда, когда локальное время на сервере MySQL_DB и Zabbix сервере будут различаться более чем на 10 секунд. Обратите внимание, что 'system.localtime' должен быть настроен как пассивная проверка.
Сравнение средней загрузки сегодня со средним значением загрузки за это же время вчера (использование сдвига времени в виде now-1d
).
Выражение сработает, если средняя загрузка за последний час более чем вдвое превысит среднюю загрузку за тот же час вчера.
Использование значения другого элемента данных в качестве порогового значения триггера:
last(/Template PfSense/hrStorageFree[{#SNMPVALUE}])<last(/Template PfSense/hrStorageSize[{#SNMPVALUE}])*0.1
Триггер изменит свое состояние на проблему, если количество свободного пространства на диске упадёт ниже 10 процентов.
Использование результата вычисления для получения количества триггеров больше порога:
(last(/server1/system.cpu.load[all,avg1])>5) + (last(/server2/system.cpu.load[all,avg1])>5) + (last(/server3/system.cpu.load[all,avg1])>5)>=2
Триггер изменит свое состояние на проблему, если по крайней мере два триггера в выражении будут больше 5.
Сравнение строковых значений двух элементов данных: операнды здесь - это функции, которые возвращают строки.
Проблема: создание оповещения, если версия Ubuntu отличается от версии на другом узле сети
last(/NY Zabbix server/vfs.file.contents[/etc/os-release])<>last(/LA Zabbix server/vfs.file.contents[/etc/os-release])
Сравнение двух строковых значений - операнды здесь:
Проблема: обнаружение изменений в DNS запросе
Ключ элемента данных:
с макросами, заданными как
который обычно возвращает:
Итак, наше выражение триггера определяет, если результат DNS запроса отклоняется от ожидаемого значения:
last(/Zabbix server/net.dns.record[8.8.8.8,{$WEBSITE_NAME},{$DNS_RESOURCE_RECORD_TYPE},2,1])<>"{$WEBSITE_NAME} {$DNS_RESOURCE_RECORD_TYPE} 0 mail.{$WEBSITE_NAME}"
Обратите внимание на кавычки вокруг второго операнда.
Сравнение двух строковых значений - операнды здесь:
Проблема: определить идентично ли содержимое файла /tmp/hello
следующим данным:
Опция 1) указать строку напрямую
Обратите внимание на то как экранируются символы \ и " при сравнении строки напрямую.
Опция 2) использование макроса
в выражении:
Сравнение длительных периодов.
Проблема: Загрузка Exchange сервера увеличилась более чем на 10% за последний месяц
trendavg(/Exchange/system.cpu.load,1M:now/M)>1.1*trendavg(/Exchange/system.cpu.load,1M:now/M-1M)
Вы можете также использовать поле Имени события в настройках триггера, чтобы создать осмысленное сообщение оповещения, например, для получения примерно следующего
"Load of Exchange server increased by 24% in July (0.69) comparing to June (0.56)"
имя события должно быть определено следующим образом:
Load of {HOST.HOST} server increased by {{?100*trendavg(//system.cpu.load,1M:now/M)/trendavg(//system.cpu.load,1M:now/M-1M)}.fmtnum(0)}% in {{TIME}.fmttime(%B,-1M)} ({{?trendavg(//system.cpu.load,1M:now/M)}.fmtnum(2)}) comparing to {{TIME}.fmttime(%B,-2M)} ({{?trendavg(//system.cpu.load,1M:now/M-1M)}.fmtnum(2)})
Также для подобных проблем полезно было бы разрешить закрывать триггер вручную в настройках самого триггера.
Порой нам необходим некоторый интервал между состояниями ОК и Проблема, а не просто порог. Например, если мы хотим задать триггер, который переходит в состояние Проблема, когда температура в серверной комнате становится больше 20°C, и мы хотим, чтобы он оставался в этом состоянии, пока температура не опустится ниже 15°C, то просто порога в 20°C для триггера будет недостаточно.
Вместо этого нам нужно сначала задать выражение триггера для события проблемы (температура выше 20°C). Затем нам нужно задать дополнительное условие восстановления (температура ниже 15°C). Это можно сделать, задавая дополнительный параметр Выражение восстановления в настройках триггера.
В этом случае восстановление проблемы будет проходить в два этапа:
Выражение восстановления будет вычислено только, когда сначала будет решено событие о проблеме.
Выражение восстановления, которое в состоянии ИСТИНА, не решает проблему, если выражение проблемы по-прежнему равно ИСТИНА!
Температура в серверной комнате слишком высокая.
Выражение проблемы:
Выражение восстановления:
Очень мало свободного места на диске.
Выражение проблемы: если меньше 10ГБ за последние 5 минут
Выражение восстановления: если больше 40ГБ за последние 10 минут
Версии до Zabbix 3.2 очень строго относились к неподдерживаемым элементам данных в выражениях триггеров. Любой неподдерживаемый элемент данных в выражении незамедлительно менял значение триггера на Неизвестно
.
Начиная с Zabbix 3.2 применен более гибкий подход к неподдерживаемым элементам данных, при вычислении выражений допускаются неизвестные значения:
or
Неподдерживаемый_элемент_данных1.некая_функция() or
Неподдерживаемый_элемент_данных2. некая_функция() or
..." может быть вычислена как '1' (Правда),and
Неподдерживаемый_элемент_данных1. некая_функция() and
Неподдерживаемый_элемент_данных2. некая_функция() and
..." может быть вычислена как '0' (Ложь).Неизвестные
значения. В двух случаях, упомянутых выше, будет приниматься во внимание известное значение; в остальных случаях значением триггера будет Неизвестно
.Неизвестно
и оно будет частью дальнейшего вычисления выражения.Обратите внимание на то, что неизвестные значения могут "исчезать" только в логических выражениях описанных выше. В арифметических выражениях неизвестные значения всегда приводят к Неизвестному
результату (за исключением деления на 0).
Если выражение триггера с несколькими неподдерживаемыми элементами данных вычисляется как Неизвестное
, сообщение об ошибке в веб-интерфейсе ссылается на последний вычисленный неподдерживаемый элемент данных.
Have a trigger expressions example that might be useful to others? Use the Example suggestion form to send it to Zabbix developers.