Сборка и установка системы мониторинга Zabbix из исходного кода (Часть 1)

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

Исходные данные: Сервер с Debian 9.11 + MySQL (MariaDB 10.4)
Задача (Часть 1): Собрать систему мониторинга Zabbix v4.4 из исходного кода и запустить основные компоненты (zabbix-server, zabbix-proxy, zabbix-agent).
Задача (Часть 2): Настроить работу Web-frontend системы мониторинга Zabbix v4.4 из исходного кода.

Для начала хотелось бы рассказать для чего может потребоваться сборка Zabbix из исходного кода, ведь обычному администратору (пользователю) достаточно выбрать нужную версию Zabbix, указать желаемую ОС на официальной странице загрузки и будет предложено подключить репозитарий Zabbix и выдана инструкция как установить готовые сборки, но, если:
1. Вы хотите собрать некоторые компоненты Zabbix под ОС для которой нет готовых пакетов, например под какой-то узко специализированный дистрибутив Linux или под такие ОС как AIX/HP-UX/Solaris;
2. Вы хотите изменить некоторые жестко установленные настройки Zabbix, которые определяются в исходном коде, например увеличить HK_MAX_DELETE_PERIODS — чтобы хаускипер в zabbix работал более активно или увеличить ZBX_MAX_HRECORDS с 1000 до 5000 чтобы zabbix-proxy выбирал из базы больше записей для отправки за 1 проход;
3. Вы хотите собрать компоненты Zabbix с поддержкой таких баз данных как Oracle;
4. Вы хотите исправить баг или что-то доработать в Zabbix самостоятельно;

то Вам пригодиться инструкция ниже как отправная точка.

Сборка Zabbix v4.4 из исходного кода достаточно подробно описана в официальной документации. Там даны только общие рекомендации и описаны основные моменты сборки, но как мы знаем — дьявол кроется в деталях и о них ниже.

ВАЖНО! Предполагается, что у Вас на сервере уже установлена MariaDB, в данной статье я не буду описывать процесс подключения репозитария MariaDB, установки и ее настройки. Если MariaDB у Вас не установлена, то Вы можете воспользоваться моей статьей. Если база данных будет (уже есть) у Вас на отдельном сервере, то на машине где Вы будите производить сборку Zabbix Вам все равно необходимо подключить репозитарий MariaDB и поставить пакет mariadb-client.

1. Подготовка сервера и установка дополнительных пакетов.

Мы будем собирать Zabbix с максимально возможным набором возможностей (функционала или features, это SNMP monitoring, IPMI monitoring, Web monitoring, VMware monitoring, SMTP authentication, ODBC, SSH2 support, IPv6 support, TLS support), для этого нам нужно установить массу дополнительных пакетов включающих компилятор gcc, утилиты для генерации сборочных сценариев, различные библиотеки разработчика и заголовочные файлы к ним.

apt-get update
apt-get install -y wget unzip
apt-get install -y autoconf automake gcc make pkg-config
apt-get install -y libxml2-dev libssl-dev libcurl4-openssl-dev libsnmp-dev snmp-mibs-downloader libevent-dev libsqlite3-dev libpcre3-dev libssh2-1-dev libopenipmi-dev unixodbc-dev libldap2-dev
apt-get install -y libmariadb-dev libmariadb-dev-compat

Я специально разбил установку пакетов на 4 строки, чтобы было более понятно что мы устанавливаем.

2. Скачивание архива с исходным кодом и распаковка.

Текущую актуальную версию Zabbix, доступную для скачивания всегда можно посмотреть на официальной странице.

На текущий момент это 4.4.10, скачиваем архив этой версии:

cd ~
wget https://cdn.zabbix.com/zabbix/sources/oldstable/4.4/zabbix-4.4.10.tar.gz -O zabbix-4.4.10.tar.gz
tar -zxf zabbix-4.4.10.tar.gz
cd zabbix-4.4.10

3. Сконфигурируем наш исходный код Zabbix с максимально возможным набором возможностей.

./configure --with-libevent --with-libpthread --with-zlib --with-libpcre --with-libcurl --with-libxml2 --with-net-snmp --with-openssl --enable-ipv6 --with-ssh2 --with-openipmi --with-unixodbc --with-ldap --with-mysql --enable-server --enable-proxy --enable-agent --sysconfdir=/etc/zabbix

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

***********************************************************
*            Now run 'make install'                       *
*                                                         *
*            Thank you for using Zabbix!                  *
*              <http://www.zabbix.com>                    *
***********************************************************

Это означает успешное завершение этапа конфигурирования и возможному переходу к этапу компиляции (сборки) Zabbix.

4. Сборка Zabbix

Здесь все просто, запускаем make (для ускорения в 4 потока):

make -j4

По окончании сборки не должно возникнуть ошибок и в конце будет выведена строка:

make[1]: Leaving directory '/root/zabbix-4.4.10'

Теперь проверим наличие собранных бинарных файлов Zabbix с помощью утилиты file:

# file src/zabbix_agent/zabbix_agentd
src/zabbix_agent/zabbix_agentd: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=7f09fe17930a98369ea580601d6e45569c4048df, not stripped

# file src/zabbix_sender/zabbix_sender
src/zabbix_sender/zabbix_sender: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=c6c9ef58ca7e6d0d28a48195940654efb5e21e46, not stripped

# file src/zabbix_get/zabbix_get
src/zabbix_get/zabbix_get: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=22b95e82e56a0230ec7cee6e8d1b704f36ac2435, not stripped

# file src/zabbix_server/zabbix_server
src/zabbix_server/zabbix_server: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=a7a47ea2d877726cfd8fada9b2f6057d3c95f67e, not stripped

# file src/zabbix_proxy/zabbix_proxy
src/zabbix_proxy/zabbix_proxy: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=2bb8e3365f18b37f2686a1fc34676b6bc91e4ed8, not stripped

Все файлы на месте, для удобства скопируем их в папку bin:

cp src/zabbix_{agent,sender,get,server,proxy}/zabbix_{agentd,sender,get,server,proxy} bin/ 2>/dev/null

Проверим:

# ls -l bin/
total 22148
drwxr-xr-x 3 1001 1001     4096 Aug 26 19:28 win32
drwxr-xr-x 3 1001 1001     4096 Aug 26 19:28 win64
-rwxr-xr-x 1 root root  1991128 Sep  4 01:21 zabbix_agentd
-rwxr-xr-x 1 root root   623648 Sep  4 01:21 zabbix_get
-rwxr-xr-x 1 root root  8818464 Sep  4 01:21 zabbix_proxy
-rwxr-xr-x 1 root root   962232 Sep  4 01:21 zabbix_sender
-rwxr-xr-x 1 root root 10267704 Sep  4 01:21 zabbix_server

5. Создание пользователя, рабочих каталогов, копирование бинарных файлов, копирование (доп. настройка) стандартных файлов конфигурации, копирование init-скриптов.

Создание пользователя и группы:

addgroup --system --quiet zabbix
adduser --quiet --system --disabled-login --ingroup zabbix --home /var/lib/zabbix --no-create-home zabbix

Проверим:

# id zabbix
uid=108(zabbix) gid=112(zabbix) groups=112(zabbix)
# getent passwd zabbix
zabbix:x:108:112::/var/lib/zabbix:/bin/false

У Вас uid и gid будут другими — это нормально.

Создадим домашний каталог для пользователя zabbix (для работы процессов zabbix он не нужен, но он может Вам пригодиться в дальнейшем для хранения доп. файлов настроек, например для $HOME/.my.cnf):

mkdir -m u=rwx,g=rwx,o= -p /var/lib/zabbix
chown zabbix:zabbix /var/lib/zabbix

Создадим каталоги для лог-файлов:

mkdir /var/log/zabbix
chown zabbix:zabbix /var/log/zabbix

Создадим каталог для PID файлов:

mkdir /run/zabbix
chown zabbix:zabbix /run/zabbix

Создадим файлы с правилами для автоматического создания каталога /var/run/zabbix при загрузке сервера:

echo "d /var/run/zabbix 0755 zabbix zabbix - -" > /usr/lib/tmpfiles.d/zabbix-agent.conf
echo "d /var/run/zabbix 0755 zabbix zabbix - -" > /usr/lib/tmpfiles.d/zabbix-server.conf
echo "d /var/run/zabbix 0755 zabbix zabbix - -" > /usr/lib/tmpfiles.d/zabbix-proxy.conf

Скопируем собранные бинарники Zabbix:

cp bin/zabbix_agentd /usr/sbin
cp bin/zabbix_server /usr/sbin
cp bin/zabbix_proxy /usr/sbin
cp bin/zabbix_sender /usr/bin
cp bin/zabbix_get /usr/bin

Создадим каталог для файлов конфигурации и скопируем туда стандартные конфиги:

mkdir /etc/zabbix
mkdir /etc/zabbix/zabbix_agentd.d
cp conf/zabbix_{agentd,server,proxy}.conf /etc/zabbix
cp conf/zabbix_agentd/userparameter_mysql.conf /etc/zabbix/zabbix_agentd.d

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

Исправим файл конфигурации для zabbix_agentd (путь до лог файла и pid-файла):

sed -i 's/LogFile=\/tmp\/zabbix_agentd.log/LogFile=\/var\/log\/zabbix\/zabbix_agentd.log/g' /etc/zabbix/zabbix_agentd.conf
sed -i 's/# PidFile=\/tmp\/zabbix_agentd.pid/PidFile=\/run\/zabbix\/zabbix_agentd.pid/g' /etc/zabbix/zabbix_agentd.conf

Исправим файл конфигурации для zabbix_server (путь до лог файла):

sed -i 's/LogFile=\/tmp\/zabbix_server.log/LogFile=\/var\/log\/zabbix\/zabbix_server.log/g' /etc/zabbix/zabbix_server.conf
sed -i 's/# PidFile=\/tmp\/zabbix_server.pid/PidFile=\/run\/zabbix\/zabbix_server.pid/g' /etc/zabbix/zabbix_server.conf

Исправим файл конфигурации для zabbix_proxy (путь до лог и pid файла и порт для входящих соединений):

sed -i 's/LogFile=\/tmp\/zabbix_proxy.log/LogFile=\/var\/log\/zabbix\/zabbix_proxy.log/g' /etc/zabbix/zabbix_proxy.conf
sed -i 's/# PidFile=\/tmp\/zabbix_proxy.pid/PidFile=\/run\/zabbix\/zabbix_proxy.pid/g' /etc/zabbix/zabbix_proxy.conf
sed -i 's/# ListenPort=10051/ListenPort=10052/g' /etc/zabbix/zabbix_proxy.conf

К сожалению в комплекте с исходным кодом идут только init-скрипты для системы инициализации sysv, а как мы знаем в Debian 9 по умолчанию идет система инициализации systemd. Поэтому я выложил на gist.github.com стандартные unit-файлы для systemd, мы их скачаем и скорректируем.

Скачиваем:

wget https://gist.githubusercontent.com/CHERTS/84dc9b7eaa36fcc6822c274a399ac35a/raw/zabbix-agent.service -O /lib/systemd/system/zabbix-agent.service
wget https://gist.githubusercontent.com/CHERTS/53948decb8d57d5ad4dd2c9741cdbac9/raw/zabbix-server.service -O /lib/systemd/system/zabbix-server.service
wget https://gist.githubusercontent.com/CHERTS/b67c5addaa7a9785e400788cea3cdde6/raw/zabbix-proxy.service -O /lib/systemd/system/zabbix-proxy.service

Добавим запуск процессов zabbix при старте сервера:

systemctl daemon-reload
systemctl enable zabbix-agent
systemctl enable zabbix-proxy
systemctl enable zabbix-server

6. Создание базы данных для zabbix-server и zabbix-proxy.

ВАЖНО! Если у Вас zabbix-server и zabbix-proxy работают на одном сервере и подключаются к одному и тому же серверу баз данных, то у них должны быть разные базы!

Создание БД, пользователя и выдача прав ничем не отличаются от описанного в официальной документации.

Подключаемся к MariaDB и создаем БД для zabbix-server и zabbix-proxy, так же создаем пользователей и выдаем им права:

mysql -u root -p
или
mysql

Создаем базы и пользователей:
БД для zabbix-server: zabbix_server
Пользователь для zabbix-server: zabbix_server_user
Пароль пользователя для zabbix-server: very_big_passwd_server
БД для zabbix-proxy: zabbix_proxy
Пользователь для zabbix-proxy: zabbix_proxy_user
Пароль пользователя для zabbix-proxy: very_big_passwd_proxy

create database zabbix_server character set utf8 collate utf8_bin;
grant all privileges on zabbix_server.* to zabbix_server_user@localhost identified by 'very_big_passwd_server';

create database zabbix_proxy character set utf8 collate utf8_bin;
grant all privileges on zabbix_proxy.* to zabbix_proxy_user@localhost identified by 'very_big_passwd_proxy';

flush privileges;

Теперь нам необходимо импортировать данные в соответствующие БД. Для zabbix-server нам нужно импортировать 3 файла (schema.sql, images.sql и data.sql), для zabbix-proxy только один (schema.sql).
Все нужные нам файлы находятся в каталоге database/mysql/
Напомню, что начиная с самого начала статьи мы не покидали корневой каталог с исходным кодом zabbix v4.4.10, поэтому все манипуляции мы выполняем находясь в нем.

Импортируем файлы в БД:

mysql -u zabbix_server_user -pvery_big_passwd_server zabbix_server < database/mysql/schema.sql
mysql -u zabbix_server_user -pvery_big_passwd_server zabbix_server < database/mysql/images.sql
mysql -u zabbix_server_user -pvery_big_passwd_server zabbix_server < database/mysql/data.sql

mysql -u zabbix_proxy_user -pvery_big_passwd_proxy zabbix_proxy < database/mysql/schema.sql

В процессе импорта не должно возникнуть никаких ошибок. Чтобы проверить корректность импорта можно сделать простые запросы к каждой базе, например посмотреть список таблиц или список стандартных пользователей в базе zabbix-server, попробуем вывести список пользователе в базе zabbix_server:

# mysql -u zabbix_server_user -pvery_big_passwd_server zabbix_server -e "select userid,alias from users;"
+--------+-------+
| userid | alias |
+--------+-------+
|      1 | Admin |
|      2 | guest |
+--------+-------+

Попробуем вывести список таблиц в базе zabbix_proxy (сокращенный вывод):

# mysql -u zabbix_proxy_user -pvery_big_passwd_proxy zabbix_proxy -e "show tables;"
+----------------------------+
| Tables_in_zabbix_proxy     |
+----------------------------+
| acknowledges               |
| actions                    |
| alerts                     |
.....
| widget_field               |
+----------------------------+

Мы видим, что структура баз для zabbix-server и zabbix-proxy создана и в базе zabbix-server есть первоначальные данные.
Теперь нам нужно внести в файлы конфигурации zabbix-server и zabbix-proxy данные для подключения к БД.

Меняем стандартные настройки подключения к БД для zabbix-server:

sed -i 's/DBName=zabbix/DBName=zabbix_server/g' /etc/zabbix/zabbix_server.conf
sed -i 's/DBUser=zabbix/DBUser=zabbix_server_user/g' /etc/zabbix/zabbix_server.conf
sed -i 's/# DBPassword=/DBPassword=very_big_passwd_server/g' /etc/zabbix/zabbix_server.conf

Меняем стандартные настройки подключения к БД для zabbix-proxy:

sed -i 's/DBUser=zabbix/DBUser=zabbix_proxy_user/g' /etc/zabbix/zabbix_proxy.conf
sed -i 's/# DBPassword=/DBPassword=very_big_passwd_proxy/g' /etc/zabbix/zabbix_proxy.conf

Давайте посмотрим итоговые файлы конфигурации, я исключу из вывода комментарии и оставлю только установленные нами настройки:

# cat /etc/zabbix/zabbix_agentd.conf | egrep -Ev "^\s*(;|#|$)"
PidFile=/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
Server=127.0.0.1
ServerActive=127.0.0.1
Hostname=Zabbix server
# cat /etc/zabbix/zabbix_server.conf | egrep -Ev "^\s*(;|#|$)"
LogFile=/var/log/zabbix/zabbix_server.log
PidFile=/run/zabbix/zabbix_server.pid
DBName=zabbix_server
DBUser=zabbix_server_user
DBPassword=very_big_passwd_server
Timeout=4
LogSlowQueries=3000
StatsAllowedIP=127.0.0.1
# cat /etc/zabbix/zabbix_proxy.conf | egrep -Ev "^\s*(;|#|$)"
Server=127.0.0.1
Hostname=Zabbix proxy
ListenPort=10052
LogFile=/var/log/zabbix/zabbix_proxy.log
PidFile=/run/zabbix/zabbix_proxy.pid
DBName=zabbix_proxy
DBUser=zabbix_proxy_user
DBPassword=very_big_passwd_proxy
Timeout=4
LogSlowQueries=3000
StatsAllowedIP=127.0.0.1

После того как мы указали настройки подключения к БД мы можем запустить zabbix-server, zabbix-proxy и zabbix-agent.

7. Запуск zabbix-server, zabbix-proxy, zabbix-agent и проверка лог-файлов.

Перед тем как запустить zabbix-server в первый раз мы должны запустить утилиту download-mibs (однократно), которая распакует, скомпилирует и разложит по нужным папкам MIB-файлы. Это необходимо для корректной работы SNMP мониторинга. Об этом я писал отдельную статью.
Запускаем download-mibs:

/usr/bin/download-mibs

Теперь запускаем zabbix-server:

systemctl start zabbix-server

Проверим наличие запущенных процессов:

ps -ef | grep [z]abbix_server

Результат:

zabbix    1702     1  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server
zabbix    1705  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: configuration syncer [waiting 60 sec for processes]
zabbix    1706  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: housekeeper [startup idle for 30 minutes]
zabbix    1707  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: timer #1 [updated 0 hosts, suppressed 0 events in 0.003476 sec, idle 59 sec]
zabbix    1708  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: http poller #1 [got 0 values in 0.000512 sec, idle 5 sec]
zabbix    1709  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: discoverer #1 [processed 0 rules in 0.000501 sec, idle 60 sec]
zabbix    1710  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: history syncer #1 [processed 1 values, 1 triggers in 0.043512 sec, idle 1 sec]
zabbix    1711  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: history syncer #2 [processed 0 values, 0 triggers in 0.000022 sec, idle 1 sec]
zabbix    1712  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: history syncer #3 [processed 0 values, 0 triggers in 0.000023 sec, idle 1 sec]
zabbix    1713  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: history syncer #4 [processed 0 values, 0 triggers in 0.000022 sec, idle 1 sec]
zabbix    1714  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: escalator #1 [processed 0 escalations in 0.000724 sec, idle 3 sec]
zabbix    1715  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: proxy poller #1 [exchanged data with 0 proxies in 0.000019 sec, idle 5 sec]
zabbix    1716  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: self-monitoring [processed data in 0.000017 sec, idle 1 sec]
zabbix    1717  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: task manager [processed 0 task(s) in 0.000072 sec, idle 5 sec]
zabbix    1718  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: poller #1 [got 0 values in 0.000027 sec, idle 1 sec]
zabbix    1719  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: poller #2 [got 0 values in 0.000014 sec, idle 1 sec]
zabbix    1720  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: poller #3 [got 1 values in 0.000063 sec, idle 1 sec]
zabbix    1721  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: poller #4 [got 0 values in 0.000008 sec, idle 1 sec]
zabbix    1722  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: poller #5 [got 0 values in 0.000009 sec, idle 1 sec]
zabbix    1723  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: unreachable poller #1 [got 0 values in 0.000021 sec, idle 5 sec]
zabbix    1724  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: trapper #1 [processed data in 0.000000 sec, waiting for connection]
zabbix    1725  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: trapper #2 [processed data in 0.000000 sec, waiting for connection]
zabbix    1726  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: trapper #3 [processed data in 0.000000 sec, waiting for connection]
zabbix    1727  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: trapper #4 [processed data in 0.000000 sec, waiting for connection]
zabbix    1728  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: trapper #5 [processed data in 0.000000 sec, waiting for connection]
zabbix    1731  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: icmp pinger #1 [got 0 values in 0.000103 sec, idle 5 sec]
zabbix    1732  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: alert manager #1 [sent 0, failed 0 alerts, idle 5.007666 sec during 5.007731 sec]
zabbix    1733  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: alerter #1 started
zabbix    1734  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: alerter #2 started
zabbix    1735  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: alerter #3 started
zabbix    1736  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: preprocessing manager #1 [queued 0, processed 0 values, idle 5.001677 sec during 5.001699 sec]
zabbix    1737  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: preprocessing worker #1 started
zabbix    1738  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: preprocessing worker #2 started
zabbix    1739  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: preprocessing worker #3 started
zabbix    1740  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: lld manager #1 [processed 0 LLD rules during 5.003868 sec]
zabbix    1741  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: lld worker #1 started
zabbix    1742  1702  0 00:25 ?        00:00:00 /usr/local/sbin/zabbix_server: lld worker #2 started

Мы видим, что основной процесс и множество вспомогательных процессов запустились.

Проверим вывод лог-файла /var/log/zabbix/zabbix_server.log:

cat /var/log/zabbix/zabbix_server.log

Результат:

  1702:20190905:002508.816 Starting Zabbix Server. Zabbix 4.4.10 (revision XXXXXXX).
  1702:20190905:002508.816 ****** Enabled features ******
  1702:20190905:002508.816 SNMP monitoring:           YES
  1702:20190905:002508.816 IPMI monitoring:           YES
  1702:20190905:002508.816 Web monitoring:            YES
  1702:20190905:002508.816 VMware monitoring:         YES
  1702:20190905:002508.816 SMTP authentication:       YES
  1702:20190905:002508.816 ODBC:                      YES
  1702:20190905:002508.816 SSH2 support:              YES
  1702:20190905:002508.816 IPv6 support:              YES
  1702:20190905:002508.816 TLS support:               YES
  1702:20190905:002508.816 ******************************
  1702:20190905:002508.816 using configuration file: /etc/zabbix/zabbix_server.conf
  1702:20190905:002508.840 current database version (mandatory/optional): 04040000/04040001
  1702:20190905:002508.840 required mandatory version: 04020000
  1702:20190905:002508.907 server #0 started [main process]
  1718:20190905:002508.913 server #14 started [poller #1]
  1719:20190905:002508.914 server #15 started [poller #2]
  1710:20190905:002508.914 server #6 started [history syncer #1]
  1711:20190905:002508.914 server #7 started [history syncer #2]
  1712:20190905:002508.915 server #8 started [history syncer #3]
  1713:20190905:002508.915 server #9 started [history syncer #4]
  1709:20190905:002508.915 server #5 started [discoverer #1]
  1720:20190905:002508.915 server #16 started [poller #3]
  1721:20190905:002508.916 server #17 started [poller #4]
  1722:20190905:002508.916 server #18 started [poller #5]
  1723:20190905:002508.917 server #19 started [unreachable poller #1]
  1705:20190905:002508.917 server #1 started [configuration syncer #1]
  1734:20190905:002508.922 server #28 started [alerter #2]
  1733:20190905:002508.922 server #27 started [alerter #1]
  1735:20190905:002508.922 server #29 started [alerter #3]
  1732:20190905:002508.922 server #26 started [alert manager #1]
  1731:20190905:002508.930 server #25 started [icmp pinger #1]
  1707:20190905:002508.982 server #3 started [timer #1]
  1728:20190905:002508.982 server #24 started [trapper #5]
  1727:20190905:002508.983 server #23 started [trapper #4]
  1726:20190905:002508.983 server #22 started [trapper #3]
  1725:20190905:002508.984 server #21 started [trapper #2]
  1724:20190905:002508.984 server #20 started [trapper #1]
  1708:20190905:002508.985 server #4 started [http poller #1]
  1714:20190905:002508.985 server #10 started [escalator #1]
  1716:20190905:002508.986 server #12 started [self-monitoring #1]
  1715:20190905:002508.986 server #11 started [proxy poller #1]
  1717:20190905:002508.986 server #13 started [task manager #1]
  1706:20190905:002508.987 server #2 started [housekeeper #1]
  1736:20190905:002508.987 server #30 started [preprocessing manager #1]
  1737:20190905:002508.988 server #31 started [preprocessing worker #1]
  1738:20190905:002508.988 server #32 started [preprocessing worker #2]
  1739:20190905:002508.989 server #33 started [preprocessing worker #3]
  1741:20190905:002508.989 server #35 started [lld worker #1]
  1740:20190905:002508.989 server #34 started [lld manager #1]
  1742:20190905:002508.990 server #36 started [lld worker #2]

Лог-файл так же подтверждает запуск всех основных процессов zabbix-server.

Проверим открытые порты:

netstat -ltupn | grep zabbix_server

Результат:

tcp        0      0 0.0.0.0:10051           0.0.0.0:*               LISTEN      1702/zabbix_server
tcp6       0      0 :::10051                :::*                    LISTEN      1702/zabbix_server

Мы видим, что zabbix_server открыл входящий порт 10051 для приема соединений.

Теперь запустим zabbix-proxy:

systemctl start zabbix-proxy

Проверим наличие запущенных процессов:

ps -ef | grep [z]abbix_proxy

Результат:

zabbix    7048     1  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy
zabbix    7051  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: configuration syncer [synced config 0 bytes in 0.003421 sec, idle 3600 sec]
zabbix    7052  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: heartbeat sender [sending heartbeat message failed in 0.029347 sec, idle 60 sec]
zabbix    7053  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: data sender [sent 0 values in 0.000451 sec, idle 1 sec]
zabbix    7054  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: housekeeper [startup idle for 30 minutes]
zabbix    7055  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: http poller #1 [got 0 values in 0.000474 sec, idle 5 sec]
zabbix    7056  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: discoverer #1 [processed 0 rules in 0.004028 sec, idle 60 sec]
zabbix    7057  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: history syncer #1 [processed 0 values in 0.000011 sec, idle 1 sec]
zabbix    7058  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: history syncer #2 [processed 0 values in 0.000020 sec, idle 1 sec]
zabbix    7059  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: history syncer #3 [processed 0 values in 0.000010 sec, idle 1 sec]
zabbix    7060  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: history syncer #4 [processed 0 values in 0.000020 sec, idle 1 sec]
zabbix    7061  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: self-monitoring [processed data in 0.000022 sec, idle 1 sec]
zabbix    7062  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: task manager [processed 0 task(s) in 0.000119 sec, idle 5 sec]
zabbix    7063  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: poller #1 [got 0 values in 0.000010 sec, idle 5 sec]
zabbix    7064  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: poller #2 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    7065  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: poller #3 [got 0 values in 0.000024 sec, idle 5 sec]
zabbix    7070  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: poller #4 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    7071  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: poller #5 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    7072  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: unreachable poller #1 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    7073  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: trapper #1 [processed data in 0.000000 sec, waiting for connection]
zabbix    7074  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: trapper #2 [processed data in 0.000000 sec, waiting for connection]
zabbix    7075  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: trapper #3 [processed data in 0.000000 sec, waiting for connection]
zabbix    7076  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: trapper #4 [processed data in 0.000000 sec, waiting for connection]
zabbix    7077  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: trapper #5 [processed data in 0.000000 sec, waiting for connection]
zabbix    7078  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: icmp pinger #1 [got 0 values in 0.000017 sec, idle 5 sec]
zabbix    7079  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: preprocessing manager #1 [queued 0, processed 0 values, idle 5.006199 sec during 5.006265 sec]
zabbix    7080  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: preprocessing worker #1 started
zabbix    7081  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: preprocessing worker #2 started
zabbix    7082  7048  0 00:42 ?        00:00:00 /usr/local/sbin/zabbix_proxy: preprocessing worker #3 started

Мы так же видим, что основной процесс и множество вспомогательных процессов zabbix-proxy успешно запустились.

Проверим открытые порты:

netstat -ltupn | grep zabbix_proxy

Результат:

tcp        0      0 0.0.0.0:10052           0.0.0.0:*               LISTEN      7048/zabbix_proxy
tcp6       0      0 :::10052                :::*                    LISTEN      7048/zabbix_proxy

Мы видим, что zabbix_proxy открыл входящий порт 10052 для приема соединений.

Проверим вывод лог-файла /var/log/zabbix/zabbix_proxy.log:

cat /var/log/zabbix/zabbix_proxy.log

Результат:

  7048:20190905:004207.716 Starting Zabbix Proxy (active) [Zabbix proxy]. Zabbix 4.4.10 (revision XXXXXXXXX).
  7048:20190905:004207.716 **** Enabled features ****
  7048:20190905:004207.716 SNMP monitoring:       YES
  7048:20190905:004207.716 IPMI monitoring:       YES
  7048:20190905:004207.716 Web monitoring:        YES
  7048:20190905:004207.716 VMware monitoring:     YES
  7048:20190905:004207.716 ODBC:                  YES
  7048:20190905:004207.716 SSH2 support:          YES
  7048:20190905:004207.716 IPv6 support:          YES
  7048:20190905:004207.716 TLS support:           YES
  7048:20190905:004207.716 **************************
  7048:20190905:004207.716 using configuration file: /etc/zabbix/zabbix_proxy.conf
  7048:20190905:004207.775 current database version (mandatory/optional): 04040000/04040001
  7048:20190905:004207.775 required mandatory version: 04020000
  7048:20190905:004207.945 proxy #0 started [main process]
  7064:20190905:004207.949 proxy #14 started [poller #2]
  7065:20190905:004207.953 proxy #15 started [poller #3]
  7056:20190905:004207.956 proxy #6 started [discoverer #1]
  7057:20190905:004207.957 proxy #7 started [history syncer #1]
  7061:20190905:004207.958 proxy #11 started [self-monitoring #1]
  7058:20190905:004207.958 proxy #8 started [history syncer #2]
  7059:20190905:004207.958 proxy #9 started [history syncer #3]
  7060:20190905:004207.959 proxy #10 started [history syncer #4]
  7062:20190905:004207.959 proxy #12 started [task manager #1]
  7063:20190905:004207.960 proxy #13 started [poller #1]
  7055:20190905:004207.962 proxy #5 started [http poller #1]
  7054:20190905:004207.966 proxy #4 started [housekeeper #1]
  7053:20190905:004207.966 proxy #3 started [data sender #1]
  7052:20190905:004207.968 proxy #2 started [heartbeat sender #1]
  7070:20190905:004207.970 proxy #16 started [poller #4]
  7071:20190905:004207.973 proxy #17 started [poller #5]
  7072:20190905:004207.977 proxy #18 started [unreachable poller #1]
  7073:20190905:004207.982 proxy #19 started [trapper #1]
  7051:20190905:004207.983 proxy #1 started [configuration syncer #1]
  7074:20190905:004207.984 proxy #20 started [trapper #2]
  7075:20190905:004207.989 proxy #21 started [trapper #3]
  7076:20190905:004207.991 proxy #22 started [trapper #4]
  7077:20190905:004207.993 proxy #23 started [trapper #5]
  7078:20190905:004207.995 proxy #24 started [icmp pinger #1]
  7052:20190905:004207.998 cannot send heartbeat message to server at "127.0.0.1": proxy "Zabbix proxy" not found
  7051:20190905:004207.998 cannot obtain configuration data from server at "127.0.0.1": empty string received
  7079:20190905:004207.998 proxy #25 started [preprocessing manager #1]
  7080:20190905:004207.999 proxy #26 started [preprocessing worker #1]
  7081:20190905:004208.000 proxy #27 started [preprocessing worker #2]
  7082:20190905:004208.001 proxy #28 started [preprocessing worker #3]
  7053:20190905:004208.057 cannot send proxy data to server at "127.0.0.1": proxy "Zabbix proxy" not found
  7053:20190905:004209.057 cannot send proxy data to server at "127.0.0.1": proxy "Zabbix proxy" not found

По логу мы так же видим старт всех процессов, но мы так же видим некоторые ошибки вида:

  7052:20190905:004207.998 cannot send heartbeat message to server at "127.0.0.1": proxy "Zabbix proxy" not found
  7051:20190905:004207.998 cannot obtain configuration data from server at "127.0.0.1": empty string received

и далее в логе будут регулярно появляться сообщения вида:

  7053:20190905:004208.057 cannot send proxy data to server at "127.0.0.1": proxy "Zabbix proxy" not found
  7053:20190905:004209.057 cannot send proxy data to server at "127.0.0.1": proxy "Zabbix proxy" not found

Причина в этом простая — наш zabbix-server совершенно ничего не знает о zabbix-proxy, который хочет к нему подключиться и именно поэтому процесс zabbix-proxy, да собственно и zabbix-server начали писать в свои логи, что они не знакомы друг с другом. Это досадное недоразумение мы исправим чуть позже, когда установим zabbix web-frontend и зарегистрируем через него наш zabbix-proxy, а пока мы остановим zabbix-proxy чтобы он не мусорил нам в лог-файлы.

Выполним остановку zabbix-proxy:

systemctl stop zabbix-proxy

Теперь настала очередь запустить zabbix-agent:

systemctl start zabbix-agent

Проверим наличие запущенных процессов:

ps -ef | grep [z]abbix_agent

Результат:

zabbix    7120     1  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd
zabbix    7121  7120  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd: collector [idle 1 sec]
zabbix    7122  7120  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd: listener #1 [waiting for connection]
zabbix    7123  7120  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd: listener #2 [waiting for connection]
zabbix    7124  7120  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd: listener #3 [waiting for connection]
zabbix    7125  7120  0 00:53 ?        00:00:00 /usr/local/sbin/zabbix_agentd: active checks #1 [idle 1 sec]

Проверим вывод лог-файла /var/log/zabbix/zabbix_agentd.log:

cat /var/log/zabbix/zabbix_agentd.log

Результат:

  7120:20190905:005319.587 Starting Zabbix Agent [Zabbix server]. Zabbix 4.4.10 (revision XXXXXXXXX).
  7120:20190905:005319.587 **** Enabled features ****
  7120:20190905:005319.587 IPv6 support:          YES
  7120:20190905:005319.587 TLS support:           YES
  7120:20190905:005319.587 **************************
  7120:20190905:005319.587 using configuration file: /etc/zabbix/zabbix_agentd.conf
  7120:20190905:005319.587 agent #0 started [main process]
  7125:20190905:005319.588 agent #5 started [active checks #1]
  7124:20190905:005319.589 agent #4 started [listener #3]
  7123:20190905:005319.592 agent #3 started [listener #2]
  7122:20190905:005319.593 agent #2 started [listener #1]
  7121:20190905:005319.598 agent #1 started [collector]

По логу мы так же видим старт всех процессов zabbix-agentd.

Если мы заглянем сейчас в лог нашего zabbix-server:

tail -n 4 /var/log/zabbix/zabbix_server.log

То можем увидеть такие строки:

  7026:20190905:005114.557 cannot parse proxy data from active proxy at "127.0.0.1": proxy "Zabbix proxy" not found
  7026:20190905:005115.559 cannot parse proxy data from active proxy at "127.0.0.1": proxy "Zabbix proxy" not found
  7026:20190905:005116.559 cannot parse proxy data from active proxy at "127.0.0.1": proxy "Zabbix proxy" not found
  7025:20190905:005407.217 enabling Zabbix agent checks on host "Zabbix server": host became available

Для нас будет интересна последняя строка, в которой говориться, что zabbix-server подключился к нашему zabbix-agent и начал сбор данных.

На этом первая часть статьи завершена, в следующей второй части мы рассмотрим процесс установки и запуска Web-frontend (web-интерфейса) системы мониторинга Zabbix.

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


Подписаться
Уведомить о
guest

Этот сайт использует Akismet для борьбы со спамом. Узнайте, как обрабатываются ваши данные комментариев.

0 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии
0
Оставьте комментарий! Напишите, что думаете по поводу статьи.x