Wymagania
Sprzęt
Pamięć
Zabbix wymaga zarówno pamięci fizycznej, jak i pamięci dyskowej. Wymagana ilość pamięci dyskowej zależy oczywiście od liczby hostów i parametrów, które są monitorowane. Jeśli planujesz przechowywać długą historię monitorowanych parametrów, powinieneś przewidzieć co najmniej kilka gigabajtów, aby mieć wystarczająco dużo miejsca na zapisanie historii w bazie danych. Każdy proces demona Zabbix wymaga kilku połączeń z serwerem bazy danych. Ilość pamięci przydzielonej dla połączenia zależy od konfiguracji silnika bazy danych.
Im więcej masz pamięci fizycznej, tym szybciej działa baza danych (a tym samym Zabbix).
CPU
Zabbix, a w szczególności baza danych Zabbix, może wymagać znacznych zasobów CPU w zależności od liczby monitorowanych parametrów i wybranego silnika bazy danych.
Inny sprzęt
Port komunikacji szeregowej oraz szeregowy modem GSM są wymagane do korzystania z obsługi powiadomień SMS w Zabbix. Konwerter USB-do-portu-szeregowego również będzie działać.
Przykłady konfiguracji sprzętowej
Tabela przedstawia przykłady konfiguracji sprzętowej przy założeniu platformy Linux/BSD/Unix.
Są to przykłady rozmiaru i konfiguracji sprzętowej na początek. Każda instalacja Zabbix jest unikalna. Przed wdrożeniem instalacji Zabbix do środowiska produkcyjnego należy koniecznie przeprowadzić testy wydajności systemu Zabbix w środowisku testowym lub deweloperskim, aby w pełni zrozumieć swoje wymagania.
| Rozmiar instalacji | Monitorowane metryki1 | Rdzenie CPU/vCPU | Pamięć (GiB) |
Baza danych | Amazon EC22 |
|---|---|---|---|---|---|
| Mała | 1 000 | 2 | 8 | MySQL Server, Percona Server, MariaDB Server, PostgreSQL |
m6i.large/m6g.large |
| Średnia | 10 000 | 4 | 16 | MySQL Server, Percona Server, MariaDB Server, PostgreSQL |
m6i.xlarge/m6g.xlarge |
| Duża | 100 000 | 16 | 64 | MySQL Server, Percona Server, MariaDB Server, PostgreSQL |
m6i.4xlarge/m6g.4xlarge |
| Bardzo duża | 1 000 000 | 32 | 96 | MySQL Server, Percona Server, MariaDB Server, PostgreSQL |
m6i.8xlarge/m6g.8xlarge |
1 1 metryka = 1 pozycja + 1 wyzwalacz + 1 wykres
2 Przykład z użyciem instancji Amazon EC2 ogólnego przeznaczenia, z architekturą ARM64 lub x86_64; podczas oceny i testowania instalacji Zabbix, przed wdrożeniem do środowiska produkcyjnego, należy wybrać odpowiedni typ instancji, taki jak zoptymalizowany pod kątem mocy obliczeniowej/pamięci/pamięci masowej.
Rzeczywista konfiguracja w dużym stopniu zależy od liczby aktywnych pozycji i częstotliwości odświeżania (szczegóły znajdują się w sekcji rozmiar bazy danych na tej stronie). W przypadku dużych instalacji zdecydowanie zaleca się uruchamianie bazy danych na oddzielnym serwerze.
Obsługiwane platformy
Ze względu na wymagania bezpieczeństwa oraz krytyczny charakter serwera monitoringu, UNIX jest jedynym systemem operacyjnym, który może stale zapewniać wymaganą wydajność, odporność na awarie i niezawodność. Zabbix działa na wiodących na rynku wersjach systemów.
Komponenty Zabbix są dostępne i przetestowane dla następujących platform:
| Platforma | Serwer | Agent | Agent 2 | Uwagi |
|---|---|---|---|---|
| Linux | x | x | x | |
| Windows | - | x | x | Agent Zabbix jest obsługiwany we wszystkich desktopowych i serwerowych wersjach systemu od Windows XP (64-bit)/Server 2003. Agent Zabbix 2 jest obsługiwany we wszystkich desktopowych i serwerowych wersjach systemu od Windows 10 (32-bit)/Server 2016, ponieważ jest kompilowany wyłącznie przy użyciu obsługiwanej wersji Go, aby zapobiec krytycznym lukom bezpieczeństwa. Od Go 1.21 minimalne wymagane wersje Windows zostały podniesione, co sprawia, że Windows 10/Server 2016 jest minimalną wersją dla agenta Zabbix 2. |
| macOS | x | x | - | |
| IBM AIX | x | x | - | Agent Zabbix nie działa na platformach AIX w wersjach niższych niż 6.1 TL07 / 7.1 TL01. |
| FreeBSD | x | x | - | |
| OpenBSD | x | x | - | |
| Solaris | x | x | - | |
| NetBSD | x | x | - | |
| HP-UX | x | x | - |
Serwer/agent Zabbix może działać na innych systemach operacyjnych typu Unix.
Zabbix wyłącza zrzuty core, jeśli został skompilowany z obsługą szyfrowania, i nie uruchamia się, jeśli system nie pozwala na wyłączenie zrzutów core.
Wymagane oprogramowanie
Zabbix jest oparty na nowoczesnych serwerach WWW, wiodących silnikach baz danych oraz języku skryptowym PHP.
Zewnętrzne oprogramowanie otaczające innych producentów
Jeśli określono jako obowiązkowe, wymagane oprogramowanie/biblioteka jest bezwzględnie konieczne. Opcjonalne składniki są potrzebne do obsługi niektórych określonych funkcji.
| Oprogramowanie | Status obowiązkowości | Obsługiwane wersje | Uwagi |
|---|---|---|---|
| MySQL/Percona | Jedno z | 8.4.0-9.5.X | Wymagane, jeśli MySQL (lub Percona) jest używane jako baza danych backendowa Zabbix. Wymagany jest silnik InnoDB. Zalecamy użycie biblioteki C API (libmysqlclient) do budowania serwera/proxy. |
| MariaDB | 10.11.00-12.0.X | Wymagany jest silnik InnoDB. Zalecana wersja to 11.4. Zalecamy użycie biblioteki MariaDB Connector/C do budowania serwera/proxy. Zobacz także: Possible deadlocks with MariaDB oraz Access to UI elements with MariaDB 10.5.1–10.5.9. |
|
| PostgreSQL | 15.0-18.X | Wymagane, jeśli PostgreSQL jest używany jako baza danych backendowa Zabbix. W zależności od rozmiaru instalacji może być konieczne zwiększenie właściwości konfiguracyjnej PostgreSQL work_mem (domyślną wartością jest 4MB), tak aby ilość pamięci używanej przez bazę danych dla konkretnej operacji była wystarczająca, a wykonywanie zapytań nie zajmowało zbyt dużo czasu. |
|
| TimescaleDB for PostgreSQL | 2.20.X-2.25.X | Wymagane, jeśli TimescaleDB jest używane jako rozszerzenie bazy danych PostgreSQL. Upewnij się, że instalujesz TimescaleDB Community Edition, która obsługuje kompresję. Należy pamiętać, że PostgreSQL 15 jest obsługiwany od TimescaleDB 2.10. Możesz także zapoznać się z TimescaleDB documentation, aby uzyskać szczegółowe informacje dotyczące zgodności wersji PostgreSQL i TimescaleDB. |
|
| SQLite | Opcjonalne | 3.3.5-3.34.X | SQLite jest obsługiwane tylko z proxy Zabbix. Wymagane, jeśli SQLite jest używane jako baza danych proxy Zabbix. |
| Elasticsearch | 7.X | Elasticsearch jest obsługiwany tylko z serwerami Zabbix, wyłącznie do przechowywania danych historycznych. Obsługa Elasticsearch jest obecnie eksperymentalna. Zobacz także wymagane oprogramowanie dla server/proxy. | |
| smartmontools | 7.1 lub nowsza | Wymagane dla Zabbix agent 2. | |
| who | Wymagane dla wtyczki zliczania użytkowników. | ||
| dpkg | Wymagane dla wtyczki system.sw.packages. | ||
| pkgtool | Wymagane dla wtyczki system.sw.packages. | ||
| rpm | Wymagane dla wtyczki system.sw.packages. | ||
| pacman | Wymagane dla wtyczki system.sw.packages. | ||
| q applets | qlist i qsize, jako część q applets, są wymagane dla wtyczki system.sw.packages w Gentoo Linux. |
Chociaż Zabbix może działać z bazami danych dostępnymi w systemach operacyjnych, dla uzyskania najlepszych rezultatów zalecamy używanie baz danych zainstalowanych z oficjalnych repozytoriów producentów baz danych.
Frontend
Minimalna obsługiwana szerokość ekranu dla frontend Zabbix wynosi 1200 px.
Jeśli oprogramowanie/biblioteka jest oznaczone jako obowiązkowe, oznacza to, że jest bezwzględnie wymagane. Elementy opcjonalne są potrzebne do obsługi niektórych określonych funkcji.
| Oprogramowanie | Status obowiązkowości | Obsługiwane wersje | Uwagi |
|---|---|---|---|
| PHP | Tak | 8.2.0 - 8.4.X | |
| Apache | Jedno z | 2.4 lub nowsza | |
| Nginx | 1.20 lub nowsza | ||
| MySQL | Jedno z | Zobacz Zewnętrzne oprogramowanie innych producentów | |
| PostgreSQL | |||
| Rozszerzenia PHP | |||
| mysqli | Tak | Wymagane, jeśli MySQL jest używany jako baza danych backend Zabbix. | |
| pgsql | Wymagane, jeśli PostgreSQL jest używany jako baza danych backend Zabbix. | ||
| bcmath | php-bcmath (--enable-bcmath) | ||
| mbstring | php-mbstring (--enable-mbstring) | ||
| sockets | php-net-socket (--enable-sockets); wymagane do obsługi skryptów użytkownika. | ||
| gd | 2.0.28 lub nowsza | php-gd (jeśli dostarczane jako osobny pakiet przez dystrybutora); rozszerzenie PHP GD musi obsługiwać obrazy PNG (--with-png-dir), obrazy JPEG (--with-jpeg-dir) oraz FreeType 2 (--with-freetype-dir). Wersja 2.3.0 lub nowsza może być wymagana, aby uniknąć możliwego nakładania się tekstu na wykresach w przypadku niektórych języków frontend. | |
| libxml | 2.6.15 lub nowsza | php-xml (jeśli dostarczane jako osobny pakiet przez dystrybutora) | |
| xmlwriter | php-xmlwriter (jeśli dostarczane jako osobny pakiet przez dystrybutora) | ||
| xmlreader | php-xmlreader (jeśli dostarczane jako osobny pakiet przez dystrybutora) | ||
| ctype | php-ctype (--enable-ctype) | ||
| session | php-session (jeśli dostarczane jako osobny pakiet przez dystrybutora) | ||
| ldap | Nie | php-ldap; wymagane do uwierzytelniania LDAP. | |
| openssl | php-openssl; wymagane do uwierzytelniania SAML. | ||
| gettext | php-gettext (--with-gettext); wymagane do tłumaczeń. | ||
| cURL | 7.19.4 lub nowsza | php-curl; wymagane dla Duo Universal Prompt MFA oraz uwierzytelniania SMTP. | |
Biblioteki frontend innych producentów dostarczane z Zabbix:
| Biblioteka | Status obowiązkowości | Dostarczana wersja | Uwagi |
|---|---|---|---|
| jQuery JavaScript Library | Tak | 3.6.0 | Biblioteka JavaScript upraszczająca proces tworzenia aplikacji działających w różnych przeglądarkach. |
| jQuery UI | 1.12.1 | Zestaw interakcji interfejsu użytkownika, efektów, widżetów i motywów zbudowanych na bazie jQuery. | |
| SAML PHP Toolkit | 4.3.1 | Zestaw narzędzi PHP, który dodaje obsługę uwierzytelniania SAML 2.0, umożliwiając logowanie do Zabbix. | |
| Symfony Yaml Component | 5.1.0 | Dodaje obsługę eksportu i importu elementów konfiguracji Zabbix w formacie YAML. |
Zabbix może działać również z wcześniejszymi wersjami Apache, MySQL i PostgreSQL.
W przypadku używania czcionek innych niż domyślna DejaVu może być wymagana funkcja PHP imagerotate. Jeśli jej brakuje, czcionki te mogą być renderowane niepoprawnie podczas wyświetlania wykresu. Ta funkcja jest dostępna tylko wtedy, gdy PHP zostało skompilowane z dołączonym GD, co nie ma miejsca w Debianie i innych dystrybucjach.
Biblioteki innych producentów używane do pisania i debugowania kodu frontend Zabbix:
| Biblioteka | Status obowiązkowości | Wersja minimalna | Opis |
|---|---|---|---|
| Composer | Nie | 2.4.1 | Menedżer pakietów dla PHP na poziomie aplikacji, który zapewnia standardowy format zarządzania zależnościami oprogramowania PHP i wymaganymi bibliotekami. |
| PHPUnit | 8.5.29 | Framework do testów jednostkowych PHP służący do testowania frontend Zabbix. | |
| SASS | 3.4.22 | Język skryptowy preprocesora, który jest interpretowany i kompilowany do kaskadowych arkuszy stylów (CSS). |
Przeglądarka internetowa po stronie klienta
Pliki cookie i JavaScript muszą być włączone.
Obsługiwane są najnowsze stabilne wersje Google Chrome, Mozilla Firefox, Microsoft Edge, Apple Safari i Opera.
Stosowana jest polityka same-origin dla IFrame, co oznacza, że Zabbix nie może być osadzony w ramkach w innej domenie.
Jednak strony osadzone w ramce Zabbix będą miały dostęp do frontend Zabbix (przez JavaScript), jeśli strona osadzona w ramce i frontend Zabbix znajdują się w tej samej domenie.
Strona taka jak http://secure-zabbix.com/cms/page.html, jeśli zostanie umieszczona na pulpitach w http://secure-zabbix.com/zabbix/, będzie miała pełny dostęp JS do Zabbix.
Serwer/proxy
Jeśli oznaczono jako obowiązkowe, wymagane oprogramowanie/biblioteka są bezwzględnie niezbędne. Opcjonalne są potrzebne do obsługi niektórych określonych funkcji.
| Wymaganie | Status obowiązkowości | Opis |
|---|---|---|
| libpcre2 | Tak | Biblioteka PCRE2 jest wymagana do obsługi Perl Compatible Regular Expression (PCRE). Obsługiwana jest PCRE2 v10.x. |
| libevent | Wymagana do komunikacji międzyprocesowej. Wersja 2.0.10 lub nowsza. | |
| libevent-pthreads | Wymagana do komunikacji międzyprocesowej. | |
| libpthread | Wymagana do obsługi mutexów i blokad odczytu-zapisu (może być częścią libc). | |
| libresolv | Wymagana do rozwiązywania nazw DNS (może być częścią libc). | |
| libiconv | Wymagana do kodowania/konwersji formatu tekstu (może być częścią libc). Obowiązkowa dla serwera Zabbix w systemie Linux. | |
| libz | Wymagana do obsługi kompresji. | |
| libm | Biblioteka matematyczna. Wymagana tylko przez serwer Zabbix. | |
| libmysqlclient | Jedna z | Wymagana, jeśli używany jest MySQL. |
| libmariadb | Wymagana, jeśli używany jest MariaDB. | |
| libpq5 | Wymagana, jeśli używany jest PostgreSQL; wersja libpq5 musi być zgodna z wersją używanej bazy danych PostgreSQL lub wyższa od niej. | |
| libsqlite3 | Wymagana, jeśli używany jest SQLite. Wymagana tylko dla Zabbix proxy. | |
| libOpenIPMI | Nie | Wymagana do obsługi IPMI. Wymagana tylko przez serwer Zabbix. |
| libssh2 lub libssh | Wymagana do kontroli SSH. Wersja 1.8.0 lub nowsza (libssh2); 0.9.0 lub nowsza (libssh). | |
| libcurl | Wymagana dla następujących funkcji: - pozycji monitorowania WWW, monitorowania VMware oraz HTTP agent (dla wszystkich: wersja 7.19.1 lub nowsza); - pozycji Zabbix agent web.page.* (wersja 7.19.1 lub nowsza; zobacz także wymagania agent); - uwierzytelniania SMTP (Basic: wersja 7.20.0 lub nowsza; OAuth: wersja 7.33 lub nowsza; zobacz także wymagania frontend); - Elasticsearch (wersja 7.28.0 lub nowsza). Zalecana jest wersja 7.28.0 lub nowsza dla wszystkich funkcji. Aby używać rozszerzonych funkcji cURL dla pozycji web.page.*, uruchom ponownie serwer/proxy Zabbix.Do uwierzytelniania SMTP używaj pakietu libcurl-full w czasie działania. |
|
| libxml2 | Wymagana do monitorowania VMware oraz preprocessingu XML XPath. | |
| net-snmp | Wymagana do obsługi SNMP. Wersja 5.3.0 lub nowsza. Obsługa silnych protokołów szyfrowania (AES192/AES192C, AES256/AES256C) jest dostępna od biblioteki net-snmp 5.8; w systemach opartych na RHEL 8+ zaleca się używanie net-snmp 5.8.15 lub nowszej. |
|
| libunixodbc | Wymagana do monitorowania baz danych. | |
| libgnutls lub libopenssl | Wymagana przy używaniu szyfrowania. Minimalne wersje: libgnutls - 3.1.18, libopenssl - 1.0.1 |
|
| libldap | Wymagana do obsługi LDAP. | |
| fping | Wymagana dla pozycji ICMP ping. | |
| c-ares | Wymagana do asynchronicznego rozwiązywania nazw DNS, jeśli Zabbix jest skonfigurowany z opcją --with-ares. W przeciwnym razie użyta zostanie libevent.Minimalna wersja: 1.16.0. Buforowanie zapytań DNS (pamięć podręczna zapytań domyślnie włączona) wymaga c-ares 1.26.0 lub nowszej. |
Agent
| Wymaganie | Status obowiązkowy | Opis |
|---|---|---|
| libpcre2 | Tak | Biblioteka PCRE2 jest wymagana do obsługi Perl Compatible Regular Expression (PCRE). Obsługiwana jest PCRE2 v10.x. Wymagana do monitorowania logów. Wymagana również w systemie Windows. |
| libpthread | Wymagana do obsługi mutexów oraz blokad odczytu-zapisu (może być częścią libc). Niewymagana w systemie Windows. | |
| libresolv | Wymagana do rozwiązywania nazw DNS (może być częścią libc). Niewymagana w systemie Windows. | |
| libiconv | Wymagana do kodowania/konwersji formatu tekstu do UTF-8 w pozycjach logów, zawartości plików, file regex oraz regmatch (może być częścią libc). Niewymagana w systemie Windows. | |
| libgnutls lub libopenssl | Nie | Wymagane w przypadku korzystania z szyfrowania. Minimalne wersje: libgnutls - 3.1.18, libopenssl - 1.0.1 W systemie Microsoft Windows wymagany jest OpenSSL 1.1.1 lub nowszy. |
| libldap | Wymagana, jeśli używany jest LDAP. Nieobsługiwana w systemie Windows. | |
| libcurl | Wymagana do rozszerzonej obsługi pozycji web.page.* w Zabbix agent. Bez libcurl dostępna jest podstawowa funkcjonalność (np. web.page.get[http://example.com]). Z libcurl agent obsługuje dodatkowe funkcje, takie jak adresy URL HTTP z poświadczeniami (np. http://user:[email protected]) oraz adresy URL HTTPS. Wymagana jest wersja 7.19.1 lub nowsza (zalecana jest wersja 7.28.0 lub nowsza). Aby używać rozszerzonych funkcji cURL, uruchom ponownie Zabbix agent. |
|
| libmodbus | Wymagana tylko w przypadku korzystania z monitorowania Modbus. Wersja 3.0 lub nowsza. |
Agent 2
| Wymaganie | Status obowiązkowy | Opis |
|---|---|---|
| Go | Tak | Wymagane do budowania Zabbix agent 2 i jego wtyczek ze źródeł. Obsługiwane jest Go 1.24.10 lub nowsze. Instrukcje instalacji znajdują się na go.dev. Biblioteki Go używane przez Zabbix agent 2 i jego wtyczki są wymienione w repozytorium Git Zabbix (biblioteki oznaczone w repozytorium jako indirect są zależnościami innych wymaganych bibliotek):- Zabbix agent 2 - Obsługa wtyczek - PostgreSQL - MongoDB - MSSQL - Ember+ - NVIDIA GPU - Przykładowa wtyczka |
| libpcre2 | Tak | Biblioteka PCRE2 jest wymagana do obsługi wyrażeń regularnych zgodnych z Perlem (PCRE). Obsługiwane jest PCRE2 v10.x. Wymagane do monitorowania logów. Wymagane również w systemie Windows. |
| libopenssl | Nie | Wymagane przy używaniu szyfrowania. Na platformach UNIX wymagany jest OpenSSL 1.0.1 lub nowszy. Biblioteka OpenSSL musi mieć włączoną obsługę PSK. LibreSSL nie jest obsługiwany. W systemach Microsoft Windows wymagany jest OpenSSL 1.1.1 lub nowszy. |
Usługa web
Najnowsza stabilna wersja Google Chrome jest obsługiwana do generowania zaplanowanych raportów przy użyciu usługi web Zabbix.
Wymagana wersja Go do budowania usługi web jest taka sama jak ta używana dla Zabbix agent 2.
Java gateway
Jeśli Zabbix został pozyskany z repozytorium kodu źródłowego lub z archiwum, wszystkie niezbędne zależności są już zawarte w drzewie źródeł.
Jeśli Zabbix został pozyskany z pakietu dostarczanego przez dystrybucję, wszystkie niezbędne zależności są już zapewniane przez system pakietów.
W obu powyższych przypadkach oprogramowanie jest gotowe do użycia i nie są wymagane żadne dodatkowe pliki do pobrania.
Jeśli jednak chcesz dostarczyć własne wersje tych zależności (na przykład podczas przygotowywania pakietu dla jakiejś dystrybucji Linuksa), poniżej znajduje się lista wersji bibliotek, z którymi Java gateway działa poprawnie. Zabbix może również działać z innymi wersjami tych bibliotek.
Poniższa tabela zawiera listę plików JAR, które są obecnie dołączane do Java gateway w oryginalnym kodzie:
| Library | Mandatory status | Bundled version | Comments |
|---|---|---|---|
| android-json | Tak | 4.3r1 | JSON (JavaScript Object Notation) to lekki format wymiany danych. Jest to zgodna z org.json implementacja Androida wyodrębniona z Android SDK. |
| logback-classic | 1.5.16 | ||
| logback-core | 1.5.16 | ||
| slf4j-api | 2.0.16 |
Java gateway można zbudować przy użyciu zarówno Oracle Java, jak i otwartego OpenJDK (wersja 1.6 lub nowsza). Pakiety dostarczane przez Zabbix są kompilowane przy użyciu OpenJDK. Poniższa tabela zawiera listę pakietów OpenJDK używanych do budowania pakietów Zabbix dla poszczególnych dystrybucji:
| Distribution | OpenJDK package |
|---|---|
| AlmaLinux 9 | java-11-openjdk-devel (amd64: 11.0.19.0.7-4; arm64: 11.0.20.0.8-3) |
| AlmaLinux 8 | java-1.8.0-openjdk-devel (amd64: 1.8.0.332.b09-2; arm64: 1.8.0.382.b05-2) |
| Amazon Linux 2023 | java-22-amazon-corretto-devel (amd64, arm64: 22.0.2+9-1) |
| CentOS Stream 9 | java-11-openjdk-devel (amd64, arm64: 11.0.18.0.10-3) |
| CentOS Stream 8 | java-1.8.0-openjdk-devel (amd64, arm64: 1.8.0.362.b08-3) |
| CentOS 7 | java-1.8.0-openjdk-devel (amd64: 1.8.0.282.b08-1) |
| Debian 12 | default-jdk-headless (amd64, arm64: 2:1.17-74) |
| Debian 11 | default-jdk-headless (amd64: 2:1.11-72) |
| OpenSUSE Leap 15 | java-17-openjdk-devel (amd64: 17.0.5.0-150400.3.9.3; arm64: 17.0.8.0-150400.3.27.1) |
| Oracle Linux 9 | java-11-openjdk-devel (amd64: 11.0.19.0.7-4.0.1; arm64: 11.0.20.0.8-2.0.1) |
| Oracle Linux 8 | java-1.8.0-openjdk-devel (amd64: 1.8.0.372.b07-4.0.1); java-11-openjdk-devel (arm64: 11.0.20.0.8-3.0.1) |
| Oracle Linux 7 | java-1.8.0-openjdk-devel (amd64: 1.8.0.282.b08-1) |
| Raspberry Pi OS 12 | default-jdk-headless (arm64, armhf: 2:1.17-74) |
| Raspberry Pi OS 11 | default-jdk-headless (arm64: 2:1.11-72; armhf: 2:1.11-72+b4) |
| RHEL 9 | java-11-openjdk-devel (amd64: 11.0.19.0.7-4; arm64: 11.0.20.0.8-3) |
| RHEL 8 | java-1.8.0-openjdk-devel (amd64: 1.8.0.372.b07-4; arm64: 1.8.0.382.b05-2) |
| RHEL 7 | java-1.8.0-openjdk-devel (amd64: 1.8.0.282.b08-1) |
| Rocky Linux 9 | java-11-openjdk-devel (amd64: 11.0.19.0.7-4; arm64: 11.0.20.0.8-3) |
| Rocky Linux 8 | java-1.8.0-openjdk-devel (amd64: 1.8.0.372.b07-4; arm64: 1.8.0.382.b05-2) |
| SLES 15 | java-17-openjdk-devel (amd64: 17.0.5.0-150400.3.9.3; arm64: 17.0.8.0-150400.3.27.1) |
| Ubuntu 24.04 | default-jdk-headless (amd64, arm64: 2:1.21-75+exp1) |
| Ubuntu 22.04 | default-jdk-headless (amd64, arm64: 2:1.11-72build2) |
| Ubuntu 20.04 | default-jdk-headless (amd64, arm64: 2:1.11-72) |
Domyślne numery portów
Poniższa lista otwartych portów dla poszczególnych komponentów ma zastosowanie do konfiguracji domyślnej:
| Komponent Zabbix | Numer portu | Protokół | Typ połączenia |
|---|---|---|---|
| Zabbix agent | 10050 | TCP | na żądanie |
| Zabbix agent 2 | 10050 | TCP | na żądanie |
| Zabbix serwer | 10051 | TCP | na żądanie |
| Zabbix proxy | 10051 | TCP | na żądanie |
| Zabbix Java gateway | 10052 | TCP | na żądanie |
| Usługa internetowa Zabbix | 10053 | TCP | na żądanie |
| Zabbix frontend | 80 | HTTP | na żądanie |
| 443 | HTTPS | na żądanie | |
| Zabbix trapper | 10051 | TCP | na żądanie |
Numery portów powinny być otwarte w zaporze sieciowej, aby umożliwić komunikację Zabbix. Wychodzące połączenia TCP zwykle nie wymagają jawnych ustawień zapory sieciowej.
Rozmiar bazy danych
Dane konfiguracyjne Zabbix wymagają stałej ilości miejsca na dysku i nie zwiększają się znacząco.
Rozmiar bazy danych Zabbix zależy głównie od następujących zmiennych, które określają ilość przechowywanych danych historycznych:
- Liczba przetwarzanych wartości na sekundę
Jest to średnia liczba nowych wartości, które serwer Zabbix otrzymuje co sekundę. Na przykład, jeśli mamy 3000 pozycji do monitorowania z interwałem odświeżania 60 sekund, liczba wartości na sekundę jest obliczana jako 3000/60 = 50.
Oznacza to, że co sekundę do bazy danych Zabbix dodawanych jest 50 nowych wartości.
- Ustawienia housekeepera dla historii
Zabbix przechowuje wartości przez stały okres czasu, zwykle kilka tygodni lub miesięcy. Każda nowa wartość wymaga określonej ilości miejsca na dysku na dane i indeks.
Jeśli więc chcemy przechowywać historię przez 30 dni i otrzymujemy 50 wartości na sekundę, całkowita liczba wartości wyniesie około (30*24*3600)* 50 = 129.600.000, czyli około 130 mln wartości.
W zależności od używanego silnika bazy danych oraz typu otrzymywanych wartości (liczby zmiennoprzecinkowe, liczby całkowite, ciągi znaków, pliki logów itp.), ilość miejsca na dysku potrzebna do przechowywania pojedynczej wartości może wynosić od 40 bajtów do setek bajtów. Zwykle dla numerycznych pozycji jest to około 90 bajtów na wartość2. W naszym przypadku oznacza to, że 130 mln wartości będzie wymagać 130 mln * 90 bajtów = 10.9GB miejsca na dysku.
Rozmiaru wartości tekstowych/logów dla pozycji nie da się dokładnie przewidzieć, ale można przyjąć około 500 bajtów na wartość.
- Ustawienie housekeepera dla trendów
Zabbix przechowuje 1-godzinny zestaw wartości maks./min./śr./liczba dla każdej pozycji w tabeli trends. Dane te są używane do analizy trendów i wykresów długookresowych. Okres jednej godziny nie może być dostosowany.
Baza danych Zabbix, w zależności od typu bazy danych, wymaga około 90 bajtów dla każdego takiego zestawu. Załóżmy, że chcemy przechowywać dane trendów przez 5 lat. Wartości dla 3000 pozycji będą wymagać 3000*24*365* 90 = 2.2GB rocznie, czyli 11GB przez 5 lat.
- Ustawienia housekeepera dla zdarzeń
Każde zdarzenie Zabbix wymaga około 250 bajtów miejsca na dysku1. Trudno oszacować liczbę zdarzeń generowanych codziennie przez Zabbix. W najgorszym przypadku można założyć, że Zabbix generuje jedno zdarzenie na sekundę.
Dla każdego odzyskanego zdarzenia tworzony jest rekord event_recovery. Zwykle większość zdarzeń zostanie odzyskana, więc można założyć jeden rekord event_recovery na zdarzenie. Oznacza to dodatkowe 80 bajtów na zdarzenie.
Opcjonalnie zdarzenia mogą mieć tagi, przy czym każdy rekord tagu wymaga około 100 bajtów miejsca na dysku1. Liczba tagów na zdarzenie (#tags) zależy od konfiguracji. Każde zdarzenie będzie więc wymagać dodatkowo #tags * 100 bajtów miejsca na dysku.
Oznacza to, że jeśli chcemy przechowywać zdarzenia przez 3 lata, będzie to wymagać 3*365*24*3600* (250+80+#tags*100) = \~30GB+#tags*100B miejsca na dysku2.
1 Więcej w przypadku nazw zdarzeń, tagów i wartości zawierających znaki spoza ASCII.
2 Przybliżenia rozmiaru opierają się na MySQL i mogą się różnić w przypadku innych baz danych.
Tabela zawiera wzory, które można wykorzystać do obliczenia ilości miejsca na dysku wymaganego przez system Zabbix:
| Parametr | Wzór na wymagane miejsce na dysku (w bajtach) |
|---|---|
| Konfiguracja Zabbix | Stały rozmiar. Zwykle 10MB lub mniej. |
| Historia | days*(items/refresh rate)*24*3600*bytes items : liczba pozycji days : liczba dni przechowywania historii refresh rate : średni interwał odświeżania pozycji bytes : liczba bajtów wymagana do przechowywania pojedynczej wartości, zależy od silnika bazy danych, zwykle \~90 bajtów. |
| Trendy | days*(items/3600)*24*3600*bytes items : liczba pozycji days : liczba dni przechowywania historii bytes : liczba bajtów wymagana do przechowywania pojedynczego trendu, zależy od silnika bazy danych, zwykle \~90 bajtów. |
| Zdarzenia | days*events*24*3600*bytes events : liczba zdarzeń na sekundę. Jedno (1) zdarzenie na sekundę w najgorszym przypadku. days : liczba dni przechowywania historii bytes : liczba bajtów wymagana do przechowywania pojedynczego zdarzenia, zależy od silnika bazy danych, zwykle \~330 + średnia liczba tagów na zdarzenie * 100 bajtów. |
Całkowite wymagane miejsce na dysku można więc obliczyć jako:
Konfiguracja + Historia + Trendy + Zdarzenia
Miejsce na dysku NIE zostanie wykorzystane natychmiast po instalacji Zabbix. Rozmiar bazy danych będzie rósł, a następnie w pewnym momencie przestanie się zwiększać, w zależności od ustawień housekeepera.
Synchronizacja czasu
Bardzo ważne jest, aby na serwerze, na którym działa Zabbix, czas systemowy był precyzyjnie ustawiony. ntpd to najpopularniejszy demon synchronizujący czas hosta z czasem innych maszyn. Zdecydowanie zaleca się utrzymywanie zsynchronizowanego czasu systemowego na wszystkich systemach, na których działają komponenty Zabbix.
Wymagania sieciowe
Poniższa lista otwartych portów dla poszczególnych komponentów ma zastosowanie do konfiguracji domyślnej.
| Components | Port |
|---|---|
| Frontend | http na 80, https na 443 |
| Server | 10051 (do użycia z aktywnym proxy/agentami) |
| Active Proxy | 10051 |
| Passive Proxy | 10051 |
| Agent2 | 10050 |
| Trapper | |
| JavaGateway | 10052 |
| WebService | 10053 |
Numery portów powinny być otwarte w zaporze sieciowej, aby umożliwić zewnętrzną komunikację z Zabbix. Wychodzące połączenia TCP zwykle nie wymagają jawnych ustawień zapory sieciowej.