Zabbix
Zabbix - система мониторинга всего, что способно ответить хоть какими то данными. Можно мониторить все, от количества установленных пакетов в системе, до температуры воздуха на кухне. Если, конечно, это чем-то мониторится. Ну и есть шаблончик соответствующий
Имеет набор достаточно разнообразных шаблонов для мониторинга Линукса, Винды, Сетевого оборудования, ИБП и прочих прикольных штук. Но если нужно сделать мониторинг чего-то специфического, то этот тот еще пердолинг. Но кто ищет тот всегда найдет. Или свой шаблон напишет. Ну или хуй положит и забьет.
Заводим Zabbix сервер на Proxmox с помощью импорта qcow2 файла
На странице https://www.zabbix.com/download_appliance выбираем нужную версию и копируем ссылку на qcow2 фаил. Этот фаил архивирован в tar.gz, поэтому скачиваем чего через wget и растариваем в папку
wget https://cdn.zabbix.com/zabbix/appliances/stable/X.X/X.X.X/zabbix_appliance-X.X.X-qcow2.tar.gz
tar -xvf zabbix_appliance-X.X.X-qcow2.tar.gz
cd zabbix_appliance-X.X.X-qcow2
Далее создаем произвольную виртуальную машину без жесткого диска. Достаточно пары гигабайт оперативной памяти и пары ядер. После создания виртуалки переходим по ssh на Proxmox и импортируем фаил виртуальной машины:
qm importdisk <VM_ID> zabbix_appliance-X.X.X.qcow2 <NAME_OF_PARTITION> --format qcow2
Где: VM_ID - идентификатор виртуальной машины, обычно трехзначное число NAME_OF_PARTITION - имя раздела на которую будем импортировать qcow2. Чаще всего это local-lvm
После импорта, диск будет привязан к виртуальной машине, но будет в состоянии Unused. Для подключения нужно выбрать диск в Hardware-опциях виртуалки и кликнуть Edit. Далее просто щекнуть по Add и диск будет добавлен
После запуска виртуалки скорее всего пригодится изменить настройки сети. Вносим правки в фаил /etc/sysconfig/network-scripts/ifcfg-eth0
и приводим к такому виду
BOOTPROTO=none IPADDR=IP_address PREFIX=24 GATEWAY=IP_gateway DNS1=IP_DNS_Server DNS2=IP_DNS_Server
Рестартим вм или сетевую службу. Далее меняем пароль для пользователя root командой passwd
Для авторизации в веб-панели Zabbix используем логин Admin
и пароль zabbix
Настройка агента zabbix-agent на Linux VM
В зависимости от целевого дистрибутива, нужно установить пакет zabbix-agent
. Я использую debian и ubuntu в качестве виртуалок, поэтому пишем:
sudo apt update
sudo apt install zabbix-agent
После установки правим /etc/zabbix/zabbix_agent.conf
изменив два параметра
Server=IP_Zabbix_Server ListenPort=10050
Перезапускаем сервис zabbix-agent
sudo systemctl restart zabbix-agent
В админ-панели переходим в Data collection
-> Hosts
-> Create host
и заводим данные о сервере на котором установили zabbix-agent В течении минуты статус ZBX у хоста должен окрасится в зеленый. Если статус красный, проверьте перезапустили службу и открыт ли порт у целевой машины? Проверить порт можно командой telnet IP-OR-FQDN 10050
Настройка агента zabbix-agent на Linux VM с шифрованием PSK
Возможно есть задача по мониторингу машины которая находится где-нибудь удаленно, к примеру - VPSка
Подключаемся по ssh к удаленной машине, ставим пакет zabbix-agent
. Далее нужно сгенерируем ключ и дать ему права:
sudo openssl rand -hex 32 > /etc/zabbix/zabbix_agentd.psk
sudo chmod 644 /etc/zabbix/zabbix_agentd.psk
Теперь приводим /etc/zabbix/zabbix_agentd.conf
к такому виду
Server=IP_Adress_Zabbix_Server ListenPort=10050 TLSConnect=psk TLSAccept=psk TLSPSKFile=/etc/zabbix/zabbix_agentd.psk TLSPSKIdentity=PSK 001
Перезапускаем сервис zabbix-agent
sudo systemctl restart zabbix-agent
Содержимое файла ключа копируем в блокнот. Если необходимо - открываем порт 10050 на VDSке. В моем случае я использую UFW
sudo ufw allow 10050/tcp
На сервере заббикс добавляем хост по аналогии, но во вкладке Encryption добавляем ключ и ставим галочки как на скриншоте ниже