Zabbix Monitoring Setup - NORDABIZ-01
Informacje o serwerze
| Parametr |
Wartosc |
| Nazwa hosta |
NORDABIZ-01 |
| VM ID |
249 |
| IP |
10.22.68.249 |
| OS |
Ubuntu 22.04 LTS |
| Aplikacja |
Flask (NordaBiznes Partner) |
| Baza danych |
PostgreSQL 15 (localhost:5432) |
| Sciezka aplikacji |
/var/www/nordabiznes |
Serwer Zabbix
1. Sprawdzenie statusu Zabbix Agent
Polacz sie z serwerem i sprawdz czy agent jest zainstalowany:
ssh maciejpi@10.22.68.249
# Sprawdz status agenta (Zabbix Agent 2 - nowsza wersja)
systemctl status zabbix-agent2
# Lub starszej wersji
systemctl status zabbix-agent
# Sprawdz czy port jest otwarty
ss -tlnp | grep 10050
2. Instalacja Zabbix Agent 2 (jesli brak)
2.1 Dodanie repozytorium Zabbix
# Pobierz pakiet repozytorium dla Ubuntu 22.04
wget https://repo.zabbix.com/zabbix/7.0/ubuntu/pool/main/z/zabbix-release/zabbix-release_7.0-2+ubuntu22.04_all.deb
# Zainstaluj repozytorium
sudo dpkg -i zabbix-release_7.0-2+ubuntu22.04_all.deb
# Zaktualizuj liste pakietow
sudo apt update
2.2 Instalacja agenta
# Zainstaluj Zabbix Agent 2
sudo apt install -y zabbix-agent2 zabbix-agent2-plugin-*
# Opcjonalnie: plugin do PostgreSQL
sudo apt install -y zabbix-agent2-plugin-postgresql
2.3 Konfiguracja firewall (jesli aktywny)
# Sprawdz status UFW
sudo ufw status
# Jesli aktywny, dodaj regule dla Zabbix
sudo ufw allow from 10.22.68.126 to any port 10050 proto tcp comment "Zabbix Server"
3. Konfiguracja Zabbix Agent 2
3.1 Edycja glownego pliku konfiguracyjnego
sudo nano /etc/zabbix/zabbix_agent2.conf
3.2 Ustawienia do zmiany
# === PODSTAWOWA KONFIGURACJA ===
# Adres serwera Zabbix (pasywne sprawdzenia)
Server=10.22.68.126
# Adres serwera dla aktywnych sprawdzen
ServerActive=10.22.68.126
# Nazwa hosta - MUSI byc identyczna jak w Zabbix Server
Hostname=NORDABIZ-01
# Port nasluchiwania (domyslny)
ListenPort=10050
# Katalog na skrypty i pliki konfiguracyjne
Include=/etc/zabbix/zabbix_agent2.d/*.conf
# Poziom logowania (3 = Warning, 4 = Debug)
DebugLevel=3
# Plik logow
LogFile=/var/log/zabbix/zabbix_agent2.log
LogFileSize=10
# Timeout dla sprawdzen (sekundy)
Timeout=30
# === BEZPIECZENSTWO ===
# Wylacz zdalne komendy (bezpieczenstwo)
EnableRemoteCommands=0
# Dozwolone adresy IP serwera
AllowKey=system.run[*]
DenyKey=system.run[*]
# === BUFFERY ===
# Bufor dla aktywnych sprawdzen
BufferSend=5
BufferSize=100
3.3 Restart i wlaczenie autostartu
# Uruchom agenta
sudo systemctl start zabbix-agent2
# Wlacz autostart
sudo systemctl enable zabbix-agent2
# Sprawdz status
sudo systemctl status zabbix-agent2
# Sprawdz logi
sudo tail -f /var/log/zabbix/zabbix_agent2.log
4. UserParameters dla NordaBiznes
4.1 Utworzenie pliku konfiguracyjnego
sudo nano /etc/zabbix/zabbix_agent2.d/nordabiznes.conf
4.2 Zawartosc pliku
# ============================================
# NordaBiznes Partner - Custom Zabbix Monitoring
# Server: NORDABIZ-01 (10.22.68.249)
# ============================================
# --- FLASK APPLICATION ---
# Health check - sprawdza czy aplikacja odpowiada
# Zwraca: 1 (OK) lub 0 (FAIL)
UserParameter=nordabiznes.health,curl -s -o /dev/null -w "%%{http_code}" http://localhost:5000/health 2>/dev/null | grep -q "200" && echo 1 || echo 0
# Health check z czasem odpowiedzi (ms)
UserParameter=nordabiznes.response_time,curl -s -o /dev/null -w "%%{time_total}" http://localhost:5000/health 2>/dev/null | awk '{printf "%.0f", $1*1000}'
# Liczba aktywnych workerow Gunicorn
UserParameter=nordabiznes.workers,pgrep -f "gunicorn.*nordabiznes" | wc -l
# Status uslugi systemd
# Zwraca: 1 (running) lub 0 (stopped/failed)
UserParameter=nordabiznes.service_status,systemctl is-active nordabiznes >/dev/null 2>&1 && echo 1 || echo 0
# Uzycie pamieci przez aplikacje (MB)
UserParameter=nordabiznes.memory_mb,ps aux | grep -E "gunicorn.*nordabiznes|python.*app.py" | grep -v grep | awk '{sum+=$6} END {printf "%.0f", sum/1024}'
# --- POSTGRESQL DATABASE ---
# Sprawdz czy PostgreSQL dziala
UserParameter=postgresql.status,pg_isready -h localhost -p 5432 >/dev/null 2>&1 && echo 1 || echo 0
# Liczba aktywnych polaczen do bazy nordabiznes
UserParameter=postgresql.connections,sudo -u postgres psql -t -c "SELECT count(*) FROM pg_stat_activity WHERE datname='nordabiznes'" 2>/dev/null | tr -d ' '
# Rozmiar bazy danych (MB)
UserParameter=postgresql.db_size_mb,sudo -u postgres psql -t -c "SELECT pg_database_size('nordabiznes')/1024/1024" 2>/dev/null | tr -d ' '
# Najdluzsze aktywne zapytanie (sekundy)
UserParameter=postgresql.longest_query_sec,sudo -u postgres psql -t -c "SELECT EXTRACT(EPOCH FROM (now() - query_start))::int FROM pg_stat_activity WHERE datname='nordabiznes' AND state='active' ORDER BY query_start LIMIT 1" 2>/dev/null | tr -d ' ' || echo 0
# --- DISK USAGE ---
# Uzycie dysku /var/www/nordabiznes (MB)
UserParameter=nordabiznes.disk_usage_mb,du -sm /var/www/nordabiznes 2>/dev/null | cut -f1
# Uzycie dysku /var/www/nordabiznes (%)
UserParameter=nordabiznes.disk_percent,df /var/www/nordabiznes 2>/dev/null | tail -1 | awk '{print $5}' | tr -d '%'
# Liczba plikow w katalogu aplikacji
UserParameter=nordabiznes.file_count,find /var/www/nordabiznes -type f 2>/dev/null | wc -l
# Rozmiar logow aplikacji (MB)
UserParameter=nordabiznes.logs_size_mb,du -sm /var/log/nordabiznes* 2>/dev/null | awk '{sum+=$1} END {print sum}' || echo 0
# --- SYSTEM RESOURCES ---
# Load average (1 min)
UserParameter=system.load1,cat /proc/loadavg | cut -d' ' -f1
# Uzycie pamieci systemowej (%)
UserParameter=system.memory_percent,free | grep Mem | awk '{printf "%.1f", $3/$2 * 100}'
# Uzycie swap (%)
UserParameter=system.swap_percent,free | grep Swap | awk '{if($2>0) printf "%.1f", $3/$2 * 100; else print 0}'
# Uptime systemu (sekundy)
UserParameter=system.uptime_sec,cat /proc/uptime | cut -d' ' -f1 | cut -d'.' -f1
# --- AI CHAT METRICS ---
# Liczba wiadomosci czatu dzisiaj (wymaga dostepu do bazy)
UserParameter=nordabiznes.chat_messages_today,sudo -u postgres psql -t -d nordabiznes -c "SELECT COUNT(*) FROM ai_chat_messages WHERE created_at >= CURRENT_DATE" 2>/dev/null | tr -d ' ' || echo 0
# Liczba aktywnych konwersacji (ostatnie 24h)
UserParameter=nordabiznes.active_conversations,sudo -u postgres psql -t -d nordabiznes -c "SELECT COUNT(DISTINCT conversation_id) FROM ai_chat_messages WHERE created_at >= NOW() - INTERVAL '24 hours'" 2>/dev/null | tr -d ' ' || echo 0
4.3 Ustawienie uprawnien
# Uprawnienia do pliku konfiguracyjnego
sudo chown root:zabbix /etc/zabbix/zabbix_agent2.d/nordabiznes.conf
sudo chmod 640 /etc/zabbix/zabbix_agent2.d/nordabiznes.conf
# Zabbix user musi miec dostep do niektorych komend
# Dodaj do sudoers (bez hasla dla okreslonych komend)
sudo visudo -f /etc/sudoers.d/zabbix
4.4 Zawartosc /etc/sudoers.d/zabbix
# Zabbix agent permissions for NordaBiznes monitoring
zabbix ALL=(postgres) NOPASSWD: /usr/bin/psql
zabbix ALL=(ALL) NOPASSWD: /usr/bin/du -sm /var/www/nordabiznes*
zabbix ALL=(ALL) NOPASSWD: /usr/bin/du -sm /var/log/nordabiznes*
4.5 Restart agenta po zmianach
sudo systemctl restart zabbix-agent2
# Test UserParameters lokalnie
zabbix_agent2 -t nordabiznes.health
zabbix_agent2 -t nordabiznes.service_status
zabbix_agent2 -t postgresql.status
zabbix_agent2 -t nordabiznes.disk_usage_mb
5. Konfiguracja na serwerze Zabbix
5.1 Dodanie hosta w Zabbix UI
- Zaloguj sie do Zabbix: http://10.22.68.126/zabbix
- Idz do: Data collection -> Hosts -> Create host
- Wypelnij formularz:
| Pole |
Wartosc |
| Host name |
NORDABIZ-01 |
| Visible name |
NordaBiznes Partner (10.22.68.249) |
| Templates |
Linux by Zabbix agent, PostgreSQL by Zabbix agent 2 |
| Host groups |
Linux servers, Web servers, Databases |
| Interfaces |
Agent: 10.22.68.249:10050 |
5.2 Utworzenie dedykowanego template'u
Utworz nowy template dla NordaBiznes:
Configuration -> Templates -> Create template
| Pole |
Wartosc |
| Template name |
Template App NordaBiznes |
| Groups |
Templates/Applications |
5.3 Items do dodania w template
| Name |
Key |
Type |
Update interval |
| Flask App Health |
nordabiznes.health |
Zabbix agent |
1m |
| Flask Response Time |
nordabiznes.response_time |
Zabbix agent |
1m |
| Gunicorn Workers |
nordabiznes.workers |
Zabbix agent |
5m |
| Service Status |
nordabiznes.service_status |
Zabbix agent |
1m |
| App Memory Usage |
nordabiznes.memory_mb |
Zabbix agent |
5m |
| PostgreSQL Status |
postgresql.status |
Zabbix agent |
1m |
| DB Connections |
postgresql.connections |
Zabbix agent |
2m |
| DB Size (MB) |
postgresql.db_size_mb |
Zabbix agent |
1h |
| App Disk Usage |
nordabiznes.disk_usage_mb |
Zabbix agent |
1h |
| Chat Messages Today |
nordabiznes.chat_messages_today |
Zabbix agent |
15m |
5.4 Triggers (alarmy)
| Name |
Expression |
Severity |
| NordaBiznes app is down |
last(/NORDABIZ-01/nordabiznes.health)=0 |
High |
| NordaBiznes service stopped |
last(/NORDABIZ-01/nordabiznes.service_status)=0 |
High |
| PostgreSQL is down |
last(/NORDABIZ-01/postgresql.status)=0 |
Disaster |
| High response time (>2s) |
last(/NORDABIZ-01/nordabiznes.response_time)>2000 |
Warning |
| Low Gunicorn workers |
last(/NORDABIZ-01/nordabiznes.workers)<2 |
Warning |
| High DB connections (>80) |
last(/NORDABIZ-01/postgresql.connections)>80 |
Warning |
| High memory usage (>500MB) |
last(/NORDABIZ-01/nordabiznes.memory_mb)>500 |
Warning |
| Disk usage >5GB |
last(/NORDABIZ-01/nordabiznes.disk_usage_mb)>5120 |
Warning |
6. Testowanie polaczenia
6.1 Test z serwera Zabbix
# Na serwerze Zabbix (10.22.68.126)
zabbix_get -s 10.22.68.249 -k agent.ping
# Oczekiwany wynik: 1
zabbix_get -s 10.22.68.249 -k nordabiznes.health
# Oczekiwany wynik: 1
zabbix_get -s 10.22.68.249 -k postgresql.status
# Oczekiwany wynik: 1
6.2 Test lokalnie na NORDABIZ-01
# Na serwerze NORDABIZ-01
zabbix_agent2 -t agent.ping
zabbix_agent2 -t nordabiznes.health
zabbix_agent2 -t nordabiznes.service_status
zabbix_agent2 -t postgresql.status
zabbix_agent2 -t nordabiznes.disk_usage_mb
7. Monitorowanie SSL/TLS (opcjonalnie)
7.1 Sprawdzenie certyfikatu z zewnatrz
Dodaj na serwerze Zabbix (nie na agencie) monitoring zewnetrzny:
# External check - waznosc certyfikatu (dni)
UserParameter=ssl.days_until_expiry[*],echo | openssl s_client -servername $1 -connect $1:443 2>/dev/null | openssl x509 -noout -enddate 2>/dev/null | cut -d= -f2 | xargs -I {} date -d {} +%s | awk -v now=$(date +%s) '{print int(($1-now)/86400)}'
Uzycie: ssl.days_until_expiry[nordabiznes.pl]
8. Dashboard
Zalecane widgety dla dashboardu NordaBiznes:
- Gauge: Flask Health - nordabiznes.health (0-1)
- Gauge: PostgreSQL Status - postgresql.status (0-1)
- Graph: Response Time - nordabiznes.response_time (trend)
- Graph: Memory Usage - nordabiznes.memory_mb (trend)
- Graph: DB Connections - postgresql.connections (trend)
- Counter: Chat Messages Today - nordabiznes.chat_messages_today
- Top Hosts: Active Problems - filtry dla NORDABIZ-01
9. Troubleshooting
Agent nie laczy sie z serwerem
# Sprawdz czy agent nasluchuje
ss -tlnp | grep 10050
# Sprawdz firewall
sudo ufw status
sudo iptables -L -n | grep 10050
# Sprawdz logi agenta
sudo tail -100 /var/log/zabbix/zabbix_agent2.log
# Test polaczenia TCP
nc -zv 10.22.68.126 10051
UserParameter nie zwraca danych
# Testuj lokalnie
zabbix_agent2 -t nordabiznes.health
# Sprawdz uprawnienia
ls -la /etc/zabbix/zabbix_agent2.d/
# Sprawdz skladnie
zabbix_agent2 -p | grep nordabiznes
PostgreSQL metrics nie dzialaja
# Sprawdz czy postgres jest dostepny
pg_isready -h localhost -p 5432
# Sprawdz uprawnienia zabbix do sudo
sudo -u zabbix sudo -u postgres psql -c "SELECT 1"
# Sprawdz sudoers
sudo cat /etc/sudoers.d/zabbix
10. Checklist wdrozenia
Historia zmian
| Data |
Autor |
Opis |
| 2025-12-29 |
Claude |
Utworzenie dokumentacji |