Instalacja z kontenerów
Przegląd
Ta strona opisuje, jak wdrożyć Zabbix za pomocą Docker lub Docker Compose.
Docker Compose to najszybszy sposób wdrożenia Zabbix. Odczytuje plik konfiguracyjny i automatycznie uruchamia wszystkie kontenery składające się na kompletne środowisko Zabbix, we właściwej kolejności.
Docker (ręczne wdrożenie) osiąga ten sam rezultat, wdrażając każdy komponent krok po kroku.
Wymagania wstępne
Przed rozpoczęciem upewnij się, że Docker (1.12.0 lub nowszy) jest zainstalowany w systemie. Jeśli nie, postępuj zgodnie z przewodnikiem instalacji Docker. W przypadku wdrożenia Docker Compose wymagany jest również Docker Compose (2.24.0 lub nowszy).
Niektóre komponenty Zabbix wymagają, aby na hoście uruchamiającym Docker były otwarte określone porty (np. 10051/TCP dla serwera Zabbix, 162/UDP dla pułapek SNMP).
Pełną listę portów używanych przez komponenty Zabbix można znaleźć w sekcji Wymagania.
W przypadku serwera Zabbix i agent domyślny port można zmienić, ustawiając zmienną środowiskową ZBX_LISTENPORT w odpowiednim kontenerze.
Dostępne obrazy Docker
Zabbix udostępnia obraz Docker dla każdego komponentu Zabbix, a wszystkie są publikowane w Docker Hub. Każdy obraz jest używany do utworzenia kontenera uruchamiającego dany komponent.
| Komponent Zabbix | Obraz Docker |
|---|---|
| agent | zabbix/zabbix-agent |
| agent 2 | zabbix/zabbix-agent2 |
| serwer (MySQL) | zabbix/zabbix-server-mysql |
| serwer (PostgreSQL) | zabbix/zabbix-server-pgsql |
| Interfejs webowy (Apache + MySQL) | zabbix/zabbix-web-apache-mysql |
| Interfejs webowy (Apache + PostgreSQL) | zabbix/zabbix-web-apache-pgsql |
| Interfejs webowy (Nginx + MySQL) | zabbix/zabbix-web-nginx-mysql |
| Interfejs webowy (Nginx + PostgreSQL) | zabbix/zabbix-web-nginx-pgsql |
| proxy (SQLite3) | zabbix/zabbix-proxy-sqlite3 |
| proxy (MySQL) | zabbix/zabbix-proxy-mysql |
| Java gateway | zabbix/zabbix-java-gateway |
| Usługa webowa | zabbix/zabbix-web-service |
| Pułapki SNMP | zabbix/zabbix-snmptraps |
Aby używać pułapek SNMP, kontener pułapek SNMP musi współdzielić wolumin z kontenerem serwera Zabbix lub proxy (zobacz jak używać tego obrazu w Docker Hub oraz przykład poniżej).
Wszystkie obrazy komponentów Zabbix w Docker Hub są oparte na najnowszych głównych wersjach obsługiwanych systemów operacyjnych. Obrazy te są automatycznie przebudowywane po zaktualizowaniu bazowych obrazów systemu operacyjnego.
Tagi obrazów
Każdy obraz obsługuje tagi umożliwiające wybór bazowego systemu operacyjnego i wersji Zabbix:
zabbix/<image>:<os>-<version>
Obsługiwane wartości <os>:
alpine- Alpine Linuxubuntu- Ubuntucentos- CentOS Streamol- Oracle Linuxltsc2022- Windows 11 LTSC 2022 (tylko Zabbix agent)
Obsługiwane wartości <version>:
latest- Najnowsza stabilna wersja Zabbix na Alpine Linux<os>-latest- Najnowsza stabilna wersja Zabbix w wybranym systemie operacyjnym<os>-trunk- Najnowsza wersja rozwojowa (nightly) w wybranym systemie operacyjnym<os>-X.X-latest- Najnowsze wydanie poboczne Zabbix dla określonej wersji głównej Zabbix w wybranym systemie operacyjnym<os>-X.X.*- Określone wydanie poboczne Zabbix w wybranym systemie operacyjnym
Przykłady:
# Najnowszy stabilny Zabbix proxy (SQLite3) na Alpine Linux:
docker pull zabbix/zabbix-proxy-sqlite3:latest
# Najnowszy stabilny Zabbix proxy (SQLite3) na Ubuntu:
docker pull zabbix/zabbix-proxy-sqlite3:ubuntu-latest
# Najnowsza wersja rozwojowa (nightly) Zabbix serwer (MySQL) na Ubuntu:
docker pull zabbix/zabbix-server-mysql:ubuntu-trunk
# Najnowsze wydanie poboczne 8.0 Zabbix serwer (MySQL) na Alpine Linux:
docker pull zabbix/zabbix-server-mysql:alpine-8.0-latest
# Wersja 8.0.1 Zabbix serwer (MySQL) na Alpine Linux:
docker pull zabbix/zabbix-server-mysql:alpine-8.0.1
Docker Compose
Docker Compose to najszybszy sposób wdrożenia Zabbixa. Odczytuje plik konfiguracyjny (plik Compose) i obsługuje całą konfigurację — pobieranie obrazów Docker, tworzenie wewnętrznej sieci między kontenerami, konfigurację magazynu danych, inicjalizację bazy danych oraz uruchamianie wszystkiego we właściwej kolejności.
Repozytorium oficjalnych plików Docker Zabbixa udostępnia gotowe do użycia pliki Docker Compose oraz system konfiguracji oparty na .env, obsługujący różne systemy operacyjne, backendy baz danych i konfigurację komponentów Zabbixa.
1. Sklonuj repozytorium, przejdź do niego i przełącz się na wersję 8.0:
git clone https://github.com/zabbix/zabbix-docker.git
cd zabbix-docker
git checkout 8.0
2. (Opcjonalnie) Dostosuj wdrożenie za pomocą zmiennych środowiskowych. Ten krok można pominąć w przypadku konfiguracji domyślnej.
3. Wdróż konfigurację domyślną — serwer Zabbixa, interfejs webowy (działający na Nginx) oraz backend bazy danych (MySQL lub PostgreSQL), każdy uruchomiony w osobnym kontenerze na Alpine Linux.
# Z MySQL jako bazą danych:
docker compose -f ./compose.yaml up -d
# Z PostgreSQL jako bazą danych:
docker compose -f ./compose_pgsql.yaml up -d
Po uruchomieniu kontenerów (zwykle w ciągu 1–3 minut) serwer Zabbixa zostanie uruchomiony, a interfejs webowy będzie dostępny pod adresem http://localhost.
Użyj docker compose ps, aby sprawdzić stan kontenerów.
Wszystkie kontenery (z wyjątkiem kontenera zabbix-docker-server-db-init-1) powinny mieć status Up.
Jeśli którykolwiek ma status Exited, sprawdź jego logi pod kątem błędów za pomocą docker logs -f <container-name>.
Zmienne środowiskowe
Zachowanie Docker Compose oraz konfigurację komponentów Zabbix można dostosować za pomocą zmiennych środowiskowych.
Zmienne na poziomie Compose (zdefiniowane w pliku .env) kontrolują, które obrazy Docker, porty i zakresy adresów IP sieci są używane.
Możesz używać tych zmiennych bezpośrednio przed poleceniem docker compose albo edytować plik .env.
Na przykład poniższe polecenie wdraża kompletną wielokontenerową konfigurację Zabbix z użyciem obrazu opartego na Ubuntu (zamiast domyślnego Alpine Linux) oraz udostępnia interfejs webowy przez Nginx na niestandardowych portach HTTP (8282) i HTTPS (8443):
OS=ubuntu \
ZABBIX_WEB_NGINX_HTTP_PORT=8282 \
ZABBIX_WEB_NGINX_HTTPS_PORT=8443 \
docker compose -f ./compose.yaml up -d
Zmienne na poziomie komponentu (zdefiniowane w plikach env_vars/.env_<component>) kontrolują konfigurację komponentów Zabbix.
Edytuj odpowiedni plik .env_<component> przed uruchomieniem polecenia docker compose.
Na przykład możesz dostosować liczbę pasywnych pollerów serwera Zabbix i ustawienia pamięci podręcznej, a także skonfigurować strefę czasową interfejsu webowego, edytując następujące zmienne:
# env_vars/.env_srv
ZBX_STARTPOLLERS=20
ZBX_CACHESIZE=64M
ZBX_HISTORYCACHESIZE=32M
# env_vars/.env_web
PHP_TZ=Europe/Paris
Zmienne środowiskowe na poziomie komponentu odpowiadają parametrom konfiguracji komponentów Zabbix, ale używają innego stylu nazewnictwa (np. ZBX_STARTPOLLERS odpowiada StartPollers).
Niektóre zmienne są specyficzne dla Dockera, a niektórych parametrów konfiguracji nie można zmienić (np. PIDFile i LogType).
Podczas korzystania ze zmiennych środowiskowych zapoznaj się z sekcją Environment variables w opisie obrazu Docker każdego komponentu (Available Docker images) na Docker Hub.
Wolumeny
Docker Compose przechowuje trwałe dane w katalogu zbx_env/ utworzonym obok pliku Compose.
Ten katalog zachowuje dane komponentów między restartami i aktualizacjami kontenerów.
Zawartość zbx_env/ jest wstępnie zdefiniowana dla obrazu każdego komponentu. Na przykład:
zbx_env/etc/— używany przez kontener interfejsu webowego Zabbixzbx_env/usr/izbx_env/var/— używane przez kontener serwera Zabbix
Więcej informacji o każdym wolumenie można znaleźć w sekcji Allowed volumes w opisie obrazu Docker każdego komponentu w Docker Hub.
Makefile
Repozytorium Zabbix Dockerfiles udostępnia również Makefile jako skrót do typowych zadań Docker Compose.
Zamiast używać pełnego polecenia docker compose, możesz używać krótszych poleceń make (uruchom make help, aby zobaczyć dostępne opcje):
# Domyślne wdrożenie (serwer Zabbix, interfejs web, MySQL, wszystko na Alpine Linux)
make up
# Własne wdrożenie (serwer Zabbix, interfejs web z niestandardowymi portami Nginx, PostgreSQL, wszystko na Ubuntu)
make up \
OS=ubuntu \
DB=pgsql \
ZABBIX_WEB_NGINX_HTTP_PORT=8282 \
ZABBIX_WEB_NGINX_HTTPS_PORT=8443
Podczas zatrzymywania lub usuwania kontenerów zawsze podawaj ten sam typ bazy danych, który został wdrożony (np. make down DB=pgsql).
Domyślnie make up uruchamia tylko minimalny zestaw usług (serwer Zabbix, interfejs web i baza danych).
Dzięki temu konfiguracja pozostaje lekka i nie uruchamia komponentów, które mogą nie być potrzebne.
Aby uwzględnić dodatkowe komponenty, możesz użyć następujących profili Compose:
# Domyślne wdrożenie + agent Zabbix, Java gateway, usługa web i pułapki SNMP:
make up COMPOSE_PROFILES=full
# COMPOSE_PROFILES=full + proxy Zabbix (MySQL i SQLite3):
make up COMPOSE_PROFILES=all
Docker (ręczne wdrożenie)
Użyj ręcznego wdrożenia, gdy chcesz wdrażać Zabbix krok po kroku, uruchamiać poszczególne komponenty, integrować je z istniejącym środowiskiem lub korzystać z alternatywnego środowiska uruchomieniowego kontenerów, takiego jak Podman.
Na przykład, aby wdrożyć proxy Zabbix, uruchom następujące polecenie:
docker run --name zabbix-proxy-sqlite3 \
-e ZBX_SERVER_HOST=192.0.2.1 \
-e ZBX_PROXYMODE=0 \
-e ZBX_HOSTNAME=zabbix-proxy-sqlite3 \
-v zabbix-proxy-data:/var/lib/zabbix/db_data \
--init \
-d \
zabbix/zabbix-proxy-sqlite3:alpine-8.0-latest
To polecenie:
-
Pobiera obraz Docker
zabbix/zabbix-proxy-sqlite3:alpine-8.0-latestDocker image. -
Tworzy i uruchamia kontener
zabbix-proxy-sqlite3na podstawie obrazu Docker (z flagami--initi-d). -
Konfiguruje parametr Zabbix proxy
Serverza pomocą zmiennej środowiskowejZBX_SERVER_HOST. Ten parametr określa adres IP serwera Zabbix, z którego proxy będzie pobierać dane konfiguracyjne i do którego będzie wysyłać zebrane dane. Zwróć uwagę, że inne zmienne wymagane do działania aktywnego proxy używają wartości domyślnych i mogą zostać pominięte.
Zmienne środowiskowe odpowiadają parametrom konfiguracji komponentów Zabbix, ale używają innego stylu nazewnictwa (np. ZBX_SERVER_HOST odpowiada Server).
Niektóre zmienne są specyficzne dla Dockera, a niektórych parametrów konfiguracji nie można zmienić (np. PIDFile i LogType).
Podczas korzystania ze zmiennych środowiskowych zapoznaj się z sekcją Environment variables w opisie Docker image każdego komponentu w Docker Hub.
- Łączy lokalizację magazynu zarządzaną przez Docker (np.
/var/lib/docker/volumes/zabbix-proxy-data/) z katalogiem/var/lib/zabbixkontenera, aby dane proxy Zabbix były trwale przechowywane nawet po usunięciu kontenera.
Więcej informacji o każdym woluminie znajdziesz w sekcji Allowed volumes w opisie Docker image każdego komponentu w Docker Hub.
Po wdrożeniu kontenera proxy Zabbix możesz przejść do dodania proxy w interfejsie webowym Zabbix oraz skonfigurować hosty, które mają być monitorowane przez to proxy.
Poniższe przykłady obejmują trzy dodatkowe scenariusze wdrożenia:
- serwer Zabbix (MySQL) z Java gateway
- serwer Zabbix (PostgreSQL) z pułapkami SNMP
- serwer Zabbix (MySQL) z Java gateway na RHEL 8–10
Więcej przykładów znajdziesz w opisie Docker image każdego komponentu w Docker Hub.
Wdrożenie serwera Zabbix (MySQL) z Java gateway
Ten przykład pokazuje, jak wdrożyć serwer Zabbix z backendem MySQL, Java gateway do monitorowania JMX oraz interfejsem webowym opartym na Nginx.
1. Utwórz dedykowaną sieć Docker, aby wszystkie kontenery komponentów Zabbix mogły się wzajemnie komunikować po nazwie kontenera:
docker network create --subnet 172.20.0.0/16 --ip-range 172.20.240.0/20 zabbix-net
2. Uruchom pusty kontener serwera MySQL (zastąp zabbix_pwd i root_pwd silnymi hasłami i użyj tych wartości w kolejnych krokach):
docker run --name mysql-server -t \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e MYSQL_ROOT_PASSWORD="root_pwd" \
--network=zabbix-net \
--restart unless-stopped \
-d mysql:8.4-oracle \
--character-set-server=utf8mb4 --collation-server=utf8mb4_bin
3. Śledź logi MySQL i poczekaj, aż MySQL będzie gotowy do połączeń (użyj Ctrl+C, aby wyjść z logów):
docker logs -f mysql-server
# ... [Server] /usr/sbin/mysqld: ready for connections. ...
4. Uruchom kontener Zabbix Java gateway:
docker run --name zabbix-java-gateway -t \
--network=zabbix-net \
--restart unless-stopped \
-d zabbix/zabbix-java-gateway:alpine-8.0-latest
5. Włącz log_bin_trust_function_creators w kontenerze serwera MySQL.
Tymczasowo znosi to ograniczenia bezpieczeństwa dotyczące funkcji składowanych; ustawienie zostanie wyłączone w późniejszych krokach.
Pozwala to użytkownikowi bazy danych Zabbix tworzyć funkcje składowane bez uprawnienia SUPER, którego MySQL wymaga, gdy włączone jest binary logging (domyślnie od MySQL 8.0).
Uruchom następujące polecenie:
docker exec -it mysql-server mysql -u root -p'root_pwd' \
-e "SET GLOBAL log_bin_trust_function_creators = 1;"
6. Uruchom kontener serwera Zabbix i połącz go z kontenerami Java Gateway oraz serwera MySQL:
docker run --name zabbix-server-mysql -t \
-e DB_SERVER_HOST="mysql-server" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e ZBX_JAVAGATEWAY="zabbix-java-gateway" \
--network=zabbix-net \
-p 10051:10051 \
--restart unless-stopped \
--init \
-d zabbix/zabbix-server-mysql:alpine-8.0-latest
7. Śledź logi serwera Zabbix i poczekaj, aż serwer Zabbix zakończy inicjalizację schematu bazy danych (użyj Ctrl+C, aby wyjść z logów):
docker logs -f zabbix-server-mysql
# ... [info]: ** Creating 'zabbix' schema in MySQL
# ... [info]: ** Database schema successfully created!
8. Wyłącz log_bin_trust_function_creators w kontenerze serwera MySQL.
Przywraca to ograniczenie bezpieczeństwa, które uniemożliwia użytkownikom innym niż SUPER tworzenie funkcji składowanych.
Uruchom następujące polecenie:
docker exec -it mysql-server mysql -u root -p'root_pwd' \
-e "SET GLOBAL log_bin_trust_function_creators = 0;"
9. Uruchom kontener interfejsu webowego Zabbix i połącz go z kontenerami serwera Zabbix oraz serwera MySQL:
docker run --name zabbix-web-nginx-mysql -t \
-e ZBX_SERVER_HOST="zabbix-server-mysql" \
-e DB_SERVER_HOST="mysql-server" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e PHP_TZ="Europe/Riga" \
--network=zabbix-net \
-p 80:8080 \
--restart unless-stopped \
-d zabbix/zabbix-web-nginx-mysql:alpine-8.0-latest
Po uruchomieniu kontenerów serwer Zabbix zostanie uruchomiony, a interfejs webowy będzie dostępny pod adresem http://localhost.
Użyj docker ps, aby sprawdzić stan kontenerów.
Wszystkie kontenery powinny mieć status Up.
Jeśli którykolwiek ma status Exited, sprawdź jego logi pod kątem błędów za pomocą docker logs -f <container-name>.
Wdrożenie serwera Zabbix (PostgreSQL) z SNMP traps
Ten przykład pokazuje, jak wdrożyć serwer Zabbix z backendem PostgreSQL, SNMP traps oraz interfejsem webowym opartym na Nginx.
1. Utwórz dedykowaną sieć Docker, aby wszystkie kontenery komponentów Zabbix mogły się wzajemnie komunikować po nazwie kontenera:
docker network create --subnet 172.20.0.0/16 --ip-range 172.20.240.0/20 zabbix-net
2. Uruchom pusty kontener serwera PostgreSQL (zastąp zabbix_pwd silnym hasłem i użyj tej wartości w kolejnych krokach):
docker run --name postgres-server -t \
-e POSTGRES_USER="zabbix" \
-e POSTGRES_PASSWORD="zabbix_pwd" \
-e POSTGRES_DB="zabbix" \
--network=zabbix-net \
--restart unless-stopped \
-d postgres:latest
3. Uruchom kontener Zabbix SNMP traps:
docker run --name zabbix-snmptraps -t \
-v /zbx_instance/snmptraps:/var/lib/zabbix/snmptraps:rw \
-v /var/lib/zabbix/mibs:/usr/share/snmp/mibs:ro \
--network=zabbix-net \
-p 162:1162/udp \
--restart unless-stopped \
-d zabbix/zabbix-snmptraps:alpine-8.0-latest
4. Uruchom kontener serwera Zabbix i połącz go z kontenerami serwera PostgreSQL oraz SNMP traps:
docker run --name zabbix-server-pgsql -t \
-e DB_SERVER_HOST="postgres-server" \
-e POSTGRES_USER="zabbix" \
-e POSTGRES_PASSWORD="zabbix_pwd" \
-e POSTGRES_DB="zabbix" \
-e ZBX_ENABLE_SNMP_TRAPS="true" \
--network=zabbix-net \
-p 10051:10051 \
--volumes-from zabbix-snmptraps \
--restart unless-stopped \
--init \
-d zabbix/zabbix-server-pgsql:alpine-8.0-latest
5. Śledź logi serwera Zabbix i poczekaj, aż serwer Zabbix zakończy inicjalizację schematu bazy danych (użyj Ctrl+C, aby wyjść z logów):
docker logs -f zabbix-server-pgsql
# ... [info]: ** Creating 'zabbix' schema in PostgreSQL
# ... [info]: ** Database schema successfully created!
6. Uruchom kontener interfejsu webowego Zabbix i połącz go z kontenerami serwera Zabbix oraz serwera PostgreSQL:
docker run --name zabbix-web-nginx-pgsql -t \
-e ZBX_SERVER_HOST="zabbix-server-pgsql" \
-e DB_SERVER_HOST="postgres-server" \
-e POSTGRES_DB="zabbix" \
-e POSTGRES_USER="zabbix" \
-e POSTGRES_PASSWORD="zabbix_pwd" \
-e PHP_TZ="Europe/Riga" \
--network=zabbix-net \
-p 443:8443 \
-p 80:8080 \
-v /etc/ssl/nginx:/etc/ssl/nginx:ro \
--restart unless-stopped \
-d zabbix/zabbix-web-nginx-pgsql:alpine-8.0-latest
Po uruchomieniu kontenerów serwer Zabbix zostanie uruchomiony, a interfejs webowy będzie dostępny pod adresem http://localhost.
Użyj docker ps, aby sprawdzić stan kontenerów.
Wszystkie kontenery powinny mieć status Up.
Jeśli którykolwiek ma status Exited, sprawdź jego logi pod kątem błędów za pomocą docker logs -f <container-name>.
Wdrożenie serwera Zabbix (MySQL) z Java gateway w RHEL 8–10
Ten przykład pokazuje, jak wdrożyć serwer Zabbix z backendem MySQL, Java gateway do monitorowania JMX oraz interfejsem webowym opartym na Nginx, działające na Red Hat Enterprise Linux 8, 9 lub 10.
W Red Hat Enterprise Linux zalecanym środowiskiem uruchomieniowym kontenerów jest Podman zamiast Docker. Podman działa podobnie do Dockera, ale nie wymaga działającej w tle usługi uruchamianej jako root, co lepiej pasuje do środowisk Red Hat.
1. Utwórz nowy pod o nazwie zabbix z wystawionymi portami dla interfejsu webowego Zabbix i trappera serwera Zabbix:
podman pod create --name zabbix -p 80:8080 -p 10051:10051
2. (Opcjonalnie) Uruchom kontener agent w lokalizacji poda zabbix:
podman run --name zabbix-agent \
-e ZBX_SERVER_HOST="127.0.0.1,localhost" \
--restart=always \
--pod=zabbix \
-d registry.connect.redhat.com/zabbix/zabbix-agent-80:latest
3. Utwórz katalog ./mysql/ na hoście RHEL:
mkdir -p ./mysql
4. Uruchom pusty kontener serwera MySQL (zastąp zabbix_pwd i root_pwd silnymi hasłami i użyj tych wartości w kolejnych krokach):
podman run --name mysql-server -t \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e MYSQL_ROOT_PASSWORD="root_pwd" \
-v ./mysql/:/var/lib/mysql/:Z \
--restart=always \
--pod=zabbix \
-d mysql:8.4 \
--character-set-server=utf8mb4 --collation-server=utf8mb4_bin
5. Śledź logi MySQL i poczekaj, aż MySQL będzie gotowy do połączeń (użyj Ctrl+C, aby wyjść z logów):
podman logs -f mysql-server
# ... [Server] /usr/sbin/mysqld: ready for connections. ...
6. Uruchom kontener Zabbix Java gateway:
podman run --name zabbix-java-gateway -t \
--restart=always \
--pod=zabbix \
-d registry.connect.redhat.com/zabbix/zabbix-java-gateway-80
7. Włącz log_bin_trust_function_creators w kontenerze serwera MySQL.
Tymczasowo znosi to ograniczenia bezpieczeństwa dotyczące funkcji składowanych; ustawienie zostanie wyłączone w późniejszych krokach.
Pozwala to użytkownikowi bazy danych Zabbix tworzyć funkcje składowane bez uprawnienia SUPER, którego MySQL wymaga, gdy włączone jest binary logging (domyślnie od MySQL 8.0).
Uruchom następujące polecenie:
podman exec -it mysql-server mysql -u root -p'root_pwd' \
-e "SET GLOBAL log_bin_trust_function_creators = 1;"
8. Uruchom kontener serwera Zabbix i połącz go z kontenerami Java Gateway oraz serwera MySQL:
podman run --name zabbix-server-mysql -t \
-e DB_SERVER_HOST="127.0.0.1" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e ZBX_JAVAGATEWAY="127.0.0.1" \
--restart=always \
--init \
--pod=zabbix \
-d registry.connect.redhat.com/zabbix/zabbix-server-mysql-80
9. Śledź logi serwera Zabbix i poczekaj, aż serwer Zabbix zakończy inicjalizację schematu bazy danych (użyj Ctrl+C, aby wyjść z logów):
podman logs -f zabbix-server-mysql
# ... [info]: ** Creating 'zabbix' schema in MySQL
# ... [info]: ** Database schema successfully created!
10. Wyłącz log_bin_trust_function_creators w kontenerze serwera MySQL.
Przywraca to ograniczenie bezpieczeństwa, które uniemożliwia użytkownikom innym niż SUPER tworzenie funkcji składowanych.
Uruchom następujące polecenie:
podman exec -it mysql-server mysql -u root -p'root_pwd' \
-e "SET GLOBAL log_bin_trust_function_creators = 0;"
11. Uruchom kontener interfejsu webowego Zabbix i połącz go z kontenerami serwera Zabbix oraz serwera MySQL:
podman run --name zabbix-web-mysql -t \
-e ZBX_SERVER_HOST="127.0.0.1" \
-e DB_SERVER_HOST="127.0.0.1" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e PHP_TZ="Europe/Riga" \
--restart=always \
--pod=zabbix \
-d registry.connect.redhat.com/zabbix/zabbix-web-mysql-80
Pod zabbix udostępnia port 80/TCP (HTTP) na hoście z portu 8080/TCP kontenera zabbix-web-mysql.
Po uruchomieniu kontenerów serwer Zabbix zostanie uruchomiony, a interfejs webowy będzie dostępny pod adresem http://localhost.
Użyj docker ps, aby sprawdzić stan kontenerów.
Wszystkie kontenery powinny mieć status Up.
Jeśli którykolwiek ma status Exited, sprawdź jego logi pod kątem błędów za pomocą docker logs -f <container-name>.