Zabbix 3.4: Макросы в интервалах времени

Привет. Продолжаем освещать нововведения Zabbix 3.4. Сегодня поговорим об использовании макросов в интервалах обновления и других временных периодах.


aqcrwymaj5v4qyqteu-ijficb-8.png


Пару слов о макросах

Пользовательские макросы — давно зарекомендовавший себя механизм, используемый в Zabbix повсеместно и дающий системе мониторинга необходимую ей гибкость. По сути это переменные, которые вы можете назначать с глобальным уровнем видимости, шаблона или узла сети. Использование макросов всячески приветствуется и рекомендуется, например в шаблонах, что делает их настраиваемыми в других окружениях и другими пользователями.
Выглядят пользовательские макросы следующим образом, вы их наверняка уже встречали:


{$MACRO}


Интервалы обновления и хранения истории

Zabbix позволяет гибко настраивать время опроса метрик: у каждой метрики может быть свой собственный интервал.


10_cfcwspbnout7u_5ritpyz9ok.png


Обновления каждой метрики также могут быть «гибкими»(см. Пользовательские интервалы), а значит происходить по определенному расписанию («раз в сутки ночью» или «в 9:00 утра в будни»).


Аналогичным образом мы можем определить время хранения истории и трендов для каждого элемента данных отдельно.


Подобная тонкость настройки нужна далеко не всегда, поэтому использование макросов дает пару новых идей по настройке этих параметров.


Варианты использования

Интервалы обновления и длительность хранения собранных данных


Во-первых, интервалы обновления метрик (как обычные, так и пользовательские интервалы), о которых сказано выше, теперь поддерживают пользовательские макросы. Во-вторых, использовать макросы можно и в интервалах хранения истории и трендов. В итоге это выглядит вот так:


kauphwlrtbd1wvabaxsfrph-t4m.png


Просто задайте значения этих макросов глобально, а потом переназначайте на уровне шаблона или узла сети, если требуется:


cun8sz3chzhzojwlvlcuatybbbe.png


В общем, для интервалов обновлений можно создать небольшой глобальный набор макросов, которые затем использовать по умолчанию для всех новых элементов данных, в зависимости от их типа и важности. Например:


hi7nwphwm8eixzchct95pox86_m.png


Это позволит не тратить каждый раз время на обдумывание «я хочу собирать эту метрику раз в 60 или раз в 61 секунду? или может раз в 5 минут будет достаточно?», а просто использовать принятые на вашем сервере и проекте правила по сбору и хранению элементов данных, зафиксированные в глобальных макросах. Хотя, возможно, такой вариант подойдет не всем :)


В низкоуровневом обнаружении


Поддерживается и контекст макросов, что может быть очень полезно, например, при LLD.
Представьте, что мы собираем трафик сетевых интерфейсов на множестве устройств. Чтобы не нагружать Zabbix, мы бы хотели сделать следующим образом:


  • ключевые интерфейсы, транки и прочие аплинки — забирать данные раз в 1 минуту, хранить историю 30 дней, а тренды 1 год.
  • остальные интерфейсы — опрашивать раз в 5 минут, хранить историю 3 дня, а тренды 1 месяц.


Для начала определим глобальные макросы {$DELAY_IF}, {$HISTORY_IF}, {$TREND_IF}:


gyfmgitpt3yfuqrqwdnzczg5cqu.png


Затем используем их в прототипе элемента данных интерфейса, но уже с контекстом (в данном случае это будет имя интерфейса ifName):


rvxgu66crsx6breo0rtdkaftcn4.png


Уже на уровне узла сети укажем новое значение макроса с контекстом для ключевого интерфейса (для примера возьмем Gi0/0.114):


sp7phoa3k4gsaqiz7cqpfqmsnhq.png


Теперь посмотрим частоту обновления и время хранения для различных интерфейсов в «Последних данных». Как видно, у нашего очень важного Gi0/0.114 теперь свои правила хранения и сбора:


3pvknpnzch9w0x0sit_8ubnnsri.png


Если же мы захотим изменить общий интервал или увеличить частоту опроса или времени хранения еще одного интерфейса — нам нужно будет просто переназначить макросы на уровне хоста. Изменять шаблон, прототип и ждать обнаружения не потребуется — все применится сразу. На самом деле, даже доступ на запись к шаблону не требуется.


Где еще?


А еще макросы теперь можно применять в других ситуациях, где нужно было указывать время или период. Например, в действиях:


qbi07ie3gljqji_w7lbiufjpqby.png


или указать через макрос время доступности инженера для автоматических уведомлений:


bjosohoe4pqosihnma-eptqfmg0.png


С точным списком мест, в которых возможно применение макросов, можно ознакомиться здесь.


В итоге

Новые возможности макросов в 3.4 открывают парочку неплохих возможностей: с одной стороны — для более тонкой настройки (для LLD), а с другой стороны — для централизации и управления временем опроса и хранения. И кстати, в интервалах времени появилась поддержка суффиксов s, m, h, d, w — мелочь, а удобно :)


До встречи!


P.S. Статья также доступна в нашем блоге на английском языке.

© Habrahabr.ru