Установка и настройка Zabbix LTS сервера

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

Компания Zabbix регулярно проводит бесплатные вебинары о решениях мониторинга, так же вы можете пройти платные курсы сертификации.

Более подробно вы можете изучить возможности на официальном сайте Zabbix LTS. Я хочу отметить важные для меня возможности:

  1. Zabbix можно развернуть локально или в облаке
  2. Реализована одна и та же политика источника для iframe, что означает, что Zabbix веб-интерфейс нельзя поместить во фреймы на другом домене
  3. Переписан Zabbix Agent с поддержкой плагинов и сохранением состояния
  4. Обнаружение счетчиков JMX (Java расширений управления)
  5. Обнаружение счетчиков производительности Windows
  6. Встроенная интеграция с системами ITSM. Zabbix представляет набор готовых интеграций со стандартными облачными и локальными системами ITSM: Jira, OTRS, Redmine, Zendesk, Zammad, Servicenow.
  7. Встроенные интеграции с системами оповещений: XMPP (Jabber), Telegram, Slack, Mattermost, Msteams, Victorops, PagerDuty, OpsGenie.
  8. Добавлены новые шаблоны и плагины для мониторинга различных сервисов, приложений и устройств. Большинство шаблонов теперь используют дополнительные возможности для автоматического обнаружения различных ресурсов. Из коробки существуют шаблоны Zabbix для ClickHouse, Mysql, Nginx, Redis, Postgresql, Haproxy, Memcached, Elasticsearch.
  9. Возможность сброса SNMP кэша, изменений контекста SNMPv3

Шаблоны Zabbix стали более сложными с кучей макросов и автообнаружений.

Фактические параметры конфигурации, сервера для Zabbix, зависят от количества активных элементов данных и частоты обновления этих элементов. До 100 устройств вам вполне хватит недорого VPS. В конфигурации Zabbix для мониторинга до 500 устройств рекомендуется CPU 2 ядра ОЗУ 2 ГБ. По ссылке я тестировал виртуальные сервера ТОП Хостингов VPS/VDS для Zabbix - рекомендую.

Минимально поддерживаемая версия PHP теперь 7.2.5, лучше PHP 8.1.

Должны быть выполнены предварительные требования по настройке вашего Linux дистрибутива, в моем случае Ubuntu 22.04.2 LTS.

  • Установите поддержку нужных языков для Zabbix, запустив команду:
    dpkg-reconfigure locales

    Как видно ниже, у меня установлены английский и русский (системным установлен английский):

    locale -a
    ...
    en_US.utf8
    ru_RU.utf8

Очень важно иметь точную дату и время системы на сервере с запущенным Zabbix. ntpd один из наиболее популярных демонов синхронизации времени хоста с временем на остальных серверах. Настоятельно рекомендуется поддерживать синхронизированное время на всех системах, где работают Zabbix компоненты.

Зададим нужный часовой пояс:

timedatectl set-timezone Europe/Kiev

В этом руководстве я буду объяснить, как установить сервер Zabbix в ОС Ubuntu.

Zabbix доступен в репозиториях пакетов Ubuntu, но я рекомендую использовать официальный репозиторий Zabbix и только LTS релизы!!! Для подключения официальных репозиториев вам нужно перейти на страницу загрузки Zabbix и выбрать вашу конфигурацию. Пример конфигурации на скриншоте:

После выбора конфигурации - ниже появятся команды для подключения репозитория, в моем случае такие:

# wget https://repo.zabbix.com/zabbix/6.0/ubuntu/pool/main/z/zabbix-release/zabbix-release_6.0-4+ubuntu22.04_all.deb
# dpkg -i zabbix-release_6.0-4+ubuntu22.04_all.deb
# apt update

Для Ubuntu 20 и ниже возможна ошибка: ( FIXME Получаем ошибку: N: Skipping acquire of configured file 'main/binary-i386/Packages' as repository 'http://repo.zabbix.com/zabbix/ /ubuntu InRelease' doesn't support architecture 'i386'

Самое интересное изучил штук 7 руководств по установке Zabbix на Ubuntu и нигде такой ошибки нет! Вопрос, а кто в интернете пишет эти руководства, на том же digitalocean и других гуру администрирования, это копипаст какой-то?!! Ладно как всегда иду на новозеландские англоязычные форумы и нахожу ответ не по Заббиксу, но решение проблемы понятно. Кому интересно это связано с мультиархитектурностью ядра Linux и поддержкой одновременно приложений i386 и amd64. Ниже команды для анализа вашего сервера по поддержке 32 и 64:

root@zab:/# dpkg --print-foreign-architectures
i386
root@zab:/# dpkg --print-architecture
amd64

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

sudo dpkg --remove-architecture i386

РЕШЕНИЕ: Правим файл /etc/apt/sources.list.d/zabbix.list и добавляем опцию [arch=amd64]. Мой измененный файл:

deb [arch=amd64] https://repo.zabbix.com/zabbix/6.0/ubuntu focal main
deb-src [arch=amd64] https://repo.zabbix.com/zabbix/6.0/ubuntu focal main

И снова запускаем

# apt update

Всё, ошибки нет!

Ранее, в этом руководстве, я самостоятельно устанавливал LAMP, пока не столкнулся с ошибкой, что установленная версия MariaDB не поддерживается Zabbix (и это на Ubuntu 20 LTS). Эта ошибка, лишний раз говорит, что Заббикс должен быть установлен на выделенном сервере и этот сервер должен выполнять задачи только мониторинга.

Для Ubuntu 20 LTS, установить MySQL 8 версии, в принципе эта версия является в Ubuntu 20 LTS базой данных по умолчанию.

apt install default-mysql-server
или можете запустить так
apt install mysql-server-8.0

Переходим к следующему шагу.

После добавления репозитория Apt установим пакеты сервера Zabbix, где пакет zabbix-server-mysql включает Zabbix сервер с поддержкой MySQL, пакет zabbix-frontend-php предоставляет веб-интерфейс для Zabbix сервера.

apt install zabbix-server-mysql zabbix-frontend-php zabbix-nginx-conf zabbix-sql-scripts zabbix-agent

Импортируем схему базы данных для Zabbix сервера. Логинемся на сервер MySQL с учетной записью root и создаем базу данных MySQL и пользователя с помощью следующих команд.

# mysql -uroot
mysql> create database zabbix character set utf8mb4 collate utf8mb4_bin;
mysql> create user zabbix@localhost identified by 'password';
mysql> grant all privileges on zabbix.* to zabbix@localhost;
mysql> set global log_bin_trust_function_creators = 1;
mysql> quit;

Импорт начальной схему и данных Заббикс производим от пользователя MySQL созданного выше.

zcat /usr/share/zabbix-sql-scripts/mysql/server.sql.gz | mysql --default-character-set=utf8mb4 -uzabbix -p zabbix
Enter password:

Выключите опцию log_bin_trust_function_creators после импорта схемы базы данных.

# mysql -uroot
mysql> set global log_bin_trust_function_creators = 0;
mysql> quit;

Ошибка импорта

Были случаи когда импорт происходит с ошибкой, в этом случае проще всего удалить таблицы и импортировать от пользователя root. Удаляем все таблицы zabbix (сама база и пользователь остаются):

mysql -Nse 'show tables' zabbix | while read table; do mysql -e "drop table $table" zabbix; done

Далее импортируем от пользователя root:

zcat /usr/share/doc/zabbix-sql-scripts/mysql/server.sql.gz | mysql -uroot -p zabbix

Настроим подключение Заббикса к базе данных, для это следует отредактировать файл /etc/zabbix/zabbix_server.conf и задать пароль для подключения к MySQL. Остальные 3 параметра уже настроены, если вы конечно не извращались с именем пользователя и базы данных.

DBPassword=password
DBHost=localhost
DBName=zabbix
DBUser=zabbix

Настройте PHP для веб-интерфейса Отредактируйте файл /etc/zabbix/nginx.conf раскомментируйте и настройте директивы 'listen' и 'server_name'.

listen 80;
server_name your_domain;

Добавляем в автозагрузку и запускаем процессы Zabbix сервера, агента и веб-сервера Nginx.

# systemctl restart zabbix-server zabbix-agent nginx php8.1-fpm
# systemctl enable zabbix-server zabbix-agent nginx php8.1-fpm

Система установлена, дальнейшая настройка через веб-установщик Zabbix, по адресу:

http://your_domain/

Почти во всех руководствах по настройке PHP идет глупый копипаст. Кроме часового пояса - ничего НЕ трогайте в php.ini, без понимания зачем вам это нужно.

date.timezone = 'Europe/Kiev' 

В этом случае я использую UFW, вы должны были на первом шаге его настроить первоначальная настройка сетевого фильтра. Далее нам нужно разрешить порты протокола HTTP, HTTPS и зарезервированные порты для работы с Zabbix агентами.

Проверяем есть ли строки в файле services, если нет дописываем

# cat /etc/services | grep Zabbix
zabbix-agent	10050/tcp			# Zabbix Agent
zabbix-agent	10050/udp			# Zabbix Agent
zabbix-trapper	10051/tcp			# Zabbix Trapper
zabbix-trapper	10051/udp			# Zabbix Trapper

Команды для UFW

$ sudo ufw allow 'Apache Full'
$ sudo ufw allow 10050
$ sudo ufw allow 10051

В итоге должна получится такая настройка фаервола:

$ sudo ufw status verbose
Status: active
Logging: on (low)
Default: deny (incoming), allow (outgoing), disabled (routed)
New profiles: skip
 
To                         Action      From
--                         ------      ----
22/tcp (OpenSSH)           ALLOW IN    Anywhere
80,443/tcp (Apache Full)   ALLOW IN    Anywhere
10050                      ALLOW IN    Anywhere
10051                      ALLOW IN    Anywhere
22/tcp (OpenSSH (v6))      ALLOW IN    Anywhere (v6)
80,443/tcp (Apache Full (v6)) ALLOW IN    Anywhere (v6)
10050 (v6)                 ALLOW IN    Anywhere (v6)
10051 (v6)                 ALLOW IN    Anywhere (v6)

Пример открытия zabbix агента на чистом iptables (замените ip сервера на свой):

iptables -A INPUT -s 10.10.0.5/32 -p tcp -m tcp --dport 10050 -j ACCEPT
iptables -A INPUT -p tcp -m tcp --dport 10050 -j DROP

Пример открытия zabbix агента для UFW

Вариант с указанием ip сервера Zabbix для IPv4
sudo ufw allow from 10.10.0.5 proto tcp to any port 10050
Вариант с указанием ip сервера Zabbix для IPv6
sudo ufw allow from 2a09:7c53::2a8 proto tcp to any port 10050

Есть хорошие правила, которые позволяют настраивать безопасно и не попадать на деньги:

  • Первое правило: НЕ существует 32 битных операционных систем, а только 64.
  • Второе правило: НЕ существует протокола HTTP, а только HTTPS.

Моя настоятельная рекомендация установить SSL сертификат на Веб интерфейс управления Заббикс, воспользуйтесь этой инструкцией.

apt install certbot python3-certbot-nginx
certbot --nginx

Откройте

http://your_domain/

(в моем случае будет конечно https), чтобы начать первоначальную настройку Zabbix. Жмем Next - проверяем зависимости PHP, если все колонки OK - жмем Next. На странице Configure DB connection вводим пароль MySQL пользователя zabbix, который был создан на Шаг 5.

На странице Zabbix server details введите имя хоста или IP-адрес хоста и номер порта сервера Zabbix, а также имя установки (необязательно). Мои настройки на скриншоте для Zabbix 5.2, для 6 -ой версии Заббикса всё ещё проще.

На вкладке GUI settings должен был подтянуться ваш часовой пояс, который прописывали на Шаг 7.

Жмем Next - проверяем суммарную информаци. Жмем Next - полeчаем сообщение о создании конфигурационного файла "/usr/share/zabbix/conf/zabbix.conf.php". Жмем Finish и переходим на страницу авторизации.

Учетные данные для доступа к веб- интерфейсу Zabbix по умолчанию

Username: Admin
Password: zabbix

Сразу меняйте пароль, переходите на страницу Administration > Users > Admin жмем Change Password.

Поздравляю, Вы установили Zabbix!

  • Скрипт для бэкапа базы данных Zabbix - https://github.com/npotorino/zabbix-backup. Позволяет выбрать, какие таблицы бэкапить со всеми данными, а для каких только структуру. Это востребовано, когда нужно перенести конфигурацию мониторинга Zabbix на другой сервер, но при этом не нужны исторические данные. Скрипт позволяет сделать полный бэкап таблиц с настройками, при этом таблицы events, history, trends перенести пустыми.
  • Zabbix Notifier add-on for Chrome

Первичная настройка отправки уведомлений в Телеграм описана в этой статье Подключаем оповещение Telegram к Zabbix. Также можно выслать графики из Zabbix в Telegram.

Кратко пошаговая инструкция для отправки сообщений в Телеграм:

Чтобы узнать id вашего аккаунта или группы, добавьте бота @my_id_bot и напишите ему /start. Альтернативный бот для определения Chat ID Echo (@chatid_echo_bot).

  1. Создаем бота, через которого будем слать оповещения из Заббикса. Для этого добавляем себе в контакты @BotFather и пишем ему сначала /start, потом /newbot. Получаем для бота token. Проверим, как работает отправка уведомлений через созданного бота. Для этого в консоли сервера, при помощи curl выполним команду:
    curl --header 'Content-Type: application/json' --request 'POST' --data '{"chat_id":"138912473","text":"Проверяю отправку оповещений ботом"}' "https://api.telegram.org/bot5318351761:AAG7wOFD6BTsfr7HA8Z7v9ejznulXxYj18/sendMessage"

    Где 138912473 id моего аккаунта. Чтобы его узнать, добавьте бота @my_id_bot и напишите ему /start. Проверяю работу бота - это nекст сообщения. bot5318351761:AA07wOFD6BTsfr7HA8Z7v9ejznulXxYj18 cлово bot и дальше token бота (пишется все в одно слово).

  2. Проверяем отправку сообщений из Zabbix: В ранних версиях (Администрирование → Способы оповещений), сейчас Alerts → Media types и выбираем Telegram. Нужно указать только токен бота внутри шаблона.
  3. Если нужно отправить оповещение в группу, то сначала создайте ее, а потом добавьте туда бота. Обязательно укажите минус в id группы.
  4. Если у вас ранее не работали никакие уведомления, то не забудьте активировать действия через Alerts → Trigger actions (в более старых версиях Configuration→ Actions → Trigger actions). Или создайте новый.
  5. В настройках пользователя добавляем ему способ оповещений через Telegram.
  6. Все работает!

Читайте также: Как Использовать Telegram API с Bash: Отправка Сообщений, Файлов, Фотографий

Система мониторинга Zabbix в стандартной установке предлагает один тип оповещений на события - одноразовое уведомление при срабатывании триггера. Часто полезны повторяющиеся напоминания о том, что проблема еще не исправлена. В разделе официальной документации Эскалации рассказано, как управлять оповещениями, в том числе делать их повторными.

Для теста удобно использовать шаблон Linux by Zabbix agent, в нем присутствует system.users.num, нужно создать триггер Number of logged in users, который срабатывает, когда залогиненных пользователей в системе становится больше двух:

Problem: last(/dieg.info/system.users.num)>=2
Recovery: last(/dieg.info/system.users.num)<2

Если вы используете sudo -i для получения прав root, то Zabbix вас будет считать как 2 разных пользователя и триггер будет срабатывать.

Далее идем в меню Настройка → Действия → Действия триггеров. Создаем новое действие:

  • Имя: Number of logged in users repeat
  • Для привязки к конкретному триггеру, в параметре Условия: Имя триггера содержит Number of logged in users

На вкладке Операции зададим такой алгоритм: повторять сообщения от 1 раз до бесконечности с интервалом 1 минута для группы Zabbix Admin. Для этого заполним:

  • Длительность шага операции по умолчанию: 1m
  • Операции: Шаг 1-0
  • Отправка группам пользователей: Zabbix Admin

Всё! Теперь вы получите 2 оповещения от стандартного правила, которое шлет один раз и от нового, которое создали. Чтобы убрать дублирование необходимо отключать стандартное оповещение и создавать свои с определенными правилами в зависимости от типа триггера.

На комплексных экранах в Zabbix можно группировать информацию с различных источников для быстрого обзора данных на одном экране. По сути комплексный экран это таблица. Нужно выбрать как много в таблице будет ячеек и какие элементы будут отображаться в этих ячейках.

Zabbix и оборудование

Zabbix мониторинг сервера баз данных Использование и настройка PostgreSQL версии 8.4.9.

  • Template Postgres. Указываем согласно руководству вместо тестовой БД "neiron" собственную. И создадим суперпользователя zabbix
    sudo -u postgres createuser zabbix
    Shall the new role be a superuser? (y/n) y
  • В конфигурационном файле zabbix-server.conf задаем путь к каталогу для внешних скриптов
    ExternalScripts=/etc/zabbix/externalscripts
  • Создайте в этом каталоге файл whois.sh. Доработанный скрипт, изначальная ревизия файла не понимала такой домен как kharkov.ua
#!/bin/bash
DOMAIN="$1"
exdate=`whois $DOMAIN | grep -E 'paid|Expire|Expiry|expires' | grep -o -E '[0-9]{4}.[0-9]{2}.[0-9]{2}|[0-9]{2}/[0-9]{2}/[0-9]{4}'`
#echo $exdate
expire=$((`date -d "$exdate" '+%s'`))
 
today=$((`date '+%s'`))
leftsec=$(($expire - $today))
leftdays=$(($leftsec/86400))
echo $leftdays
chmod +x whois.sh

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

./whois.sh dieg.info
215
  • Теперь с помощью параметра UserParameter нужно разрешить запуск этого пользовательского скрипта агентом Zabbix. Добавьте строку в файл /etc/zabbix/zabbix_agentd.conf
UserParameter=domainexpire[*],/etc/zabbix/externalscripts/whois.sh $1

Такой параметр позволит выполнить определенный внешний скрипт через агента Zabbix. Для вызова этого скрипта из Zabbix нужно использовать параметр domainexpire. Перезапускаем агента:

systemctl restart zabbix-agent.service

Проверьте, что агент zabbix может получить данные через новый параметр. Для тестирования агента используется утилита zabbix-get:

apt install zabbix-get
zabbix_get -s 127.0.0.1 -p 10050 -k domainexpire[dieg.info]

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

  • Теперь добавьте новый шаблон CheckDomainExpiration для мониторинга сроков делегирования доменов в Zabbix.

На вкладке items создаем новый итем с параметрами

Имя: Cрок регистрации домена {$DOMAINNAME}
Type: Zabbix Agent
Key: domainexpire[{$DOMAINNAME}]
Type of information: Numeric (unsigned)
Update Interval: 1d
History: 90d
Trenfd: 365d

  • Добавим новый триггер
Name: Срок регистрации домена {$DOMAINNAME} заканчивается
Expression: last(/CheckDomainExpiration/domainexpire[{$DOMAINNAME}])<39
Severity: High
  • Теперь добавьте в Zabbix новый хост для вашего доменного имени с типом интерфейса Agent. На вкладке Macros нужно указать имя домена, срок регистрации которого вы хотите отслеживать:
Macro: {$DOMAINNAME}
Value: dieg.info

Назначьте хосту ранее созданный шаблон CheckDomainExpiration. В созданном шаблоне срок регистрации домена проверяется раз в сутки. Чтобы получить данные из whois немедленно, найдите ваш параметр (item) на вкладке хоста и нажмите Execute Now.

Теперь проверьте Latest Data. Zabbix покажет через сколько дней заканчивается срок регистрации вашего домена.

По аналогии добавьте через Hosts все домены, срок регистрации которых нужно отслеживать.

PQ VPS сервера в 28+ странах.