3 Agent 2
Übersicht
Zabbix Agent 2 ist eine neue Generation des Zabbix Agent, geschrieben in Go (wobei ein Teil des C-Codes aus dem Zabbix Agent wiederverwendet wird). Er ist dafür konzipiert,:
- Die Anzahl der TCP-Verbindungen zu reduzieren;
- Eine verbesserte Parallelität von Prüfungen bereitzustellen;
- Sich mithilfe von Plugins leicht erweitern zu lassen, die einfache Prüfungen mit minimalem Code bereitstellen und komplexe Prüfungen unterstützen, die aus lang laufenden Skripten und eigenständiger Datenerfassung mit periodischer Berichterstattung bestehen;
- Als Ersatz für Zabbix Agent zu fungieren und alle bisherigen Funktionen zu unterstützen.
Alle von Zabbix Agent 2 unterstützten Metriken werden von Plugins erfasst.
Passive und aktive Prüfungen
Zabbix Agent 2 unterstützt passive und aktive Prüfungen ähnlich wie Zabbix Agent. Zusätzlich unterstützen aktive Prüfungen von Zabbix Agent 2 flexible/planungsbasierte Intervalle und Prüfungsparallelität innerhalb eines aktiven Servers.
Standardmäßig plant Zabbix Agent 2 nach einem Neustart die erste Datenerfassung für aktive Prüfungen zu einem bedingt zufälligen Zeitpunkt innerhalb des Aktualisierungsintervalls des Datenpunkts, um Spitzen bei der Ressourcennutzung zu vermeiden.
Um aktive Prüfungen, die kein Scheduling-Aktualisierungsintervall haben, unmittelbar nach dem Neustart des Agent auszuführen, setzen Sie den Parameter ForceActiveChecksOnStart (auf globaler Ebene) oder Plugins.<Plugin name>.System.ForceActiveChecksOnStart (wirkt sich nur auf Prüfungen des jeweiligen Plugins aus) in der Konfigurationsdatei fest.
Ein Parameter auf Plugin-Ebene überschreibt, falls gesetzt, den globalen Parameter.
Prüfkonkurrenz
Prüfungen aus verschiedenen Plugins können gleichzeitig ausgeführt werden.
Die Anzahl der gleichzeitigen Prüfungen innerhalb eines Plugins ist durch die Einstellung der Plugin-Kapazität begrenzt.
Jedes Plugin kann eine fest codierte Kapazitätseinstellung haben (1000 ist standardmäßig der Wert), die mit der Einstellung Plugins.<PluginName>.System.Capacity=N im Konfigurations-Parameter Plugins verringert werden kann.
Unterstützte Plattformen
Informationen zu unterstützten Plattformen finden Sie auf der Seite Anforderungen.
Agent 2 auf Unix-ähnlichen Systemen
Der Zabbix Agent 2 auf Unix-ähnlichen Systemen wird auf dem überwachten Host ausgeführt.
Installation
Zabbix Agent 2 kann auf Linux-basierten Systemen mit einer der folgenden Methoden installiert werden:
- Zabbix-Pakete - wählen Sie nach Auswahl Ihrer Zabbix-Version, Ihrer OS-Distribution und Ihrer OS-Version die Komponente Agent 2 aus und folgen Sie den Anweisungen;
- Zabbix-Quellen - laden Sie die Quelldateien herunter und kompilieren Sie den Agent durch Konfigurieren mit der Option
--enable-agent2.
Die Überwachungsfunktionen von Zabbix Agent 2 können mit ladbaren Plugins erweitert werden, die separat verfügbar sind. Weitere Informationen finden Sie unter Ladbare Plugins.
Seit Zabbix 7.0.5 sind Zabbix Agent 2-Pakete für RHEL 6 nicht mehr verfügbar, da Go 1.22 (und neuer) nicht mit GCC 4.4.7 kompatibel ist, das von RHEL 6 bereitgestellt wird, was zu Kompilierungsfehlern führt. Beachten Sie jedoch, dass Zabbix-Agent-Pakete weiterhin unterstützt werden.
Wenn als Paket installiert
Zabbix Agent 2 läuft als Vordergrundprozess und ist für die Ausführung im Hintergrund auf einen externen Dienstmanager (z. B. systemd) angewiesen. Zabbix Agent 2 verfügt unter Linux nicht über eine integrierte Unterstützung für die Daemonisierung.
Der Agent kann mit folgendem Befehl gestartet werden:
systemctl start zabbix-agent2
Zum Stoppen, Neustarten oder Prüfen des Status von Zabbix Agent 2 verwenden Sie die folgenden Befehle:
systemctl stop zabbix-agent2
systemctl restart zabbix-agent2
systemctl status zabbix-agent2
Manuell starten
Sie können den Zabbix Agent starten, indem Sie die Binärdatei zabbix_agent2 suchen und direkt ausführen; zum Beispiel:
zabbix_agent2
Agent 2 auf Windows-Systemen
Zabbix Agent 2 wird als eigenständiger Prozess ausgeführt; er kann jedoch auch als Windows-Dienst ausgeführt werden.
Installation
Zabbix Agent 2 kann unter Windows mit einer der folgenden Methoden installiert werden:
- Vorkompilierte Zabbix-Agent-Binärdateien - laden Sie das MSI-Installationspaket des Agents herunter und folgen Sie den Anweisungen auf der Seite Windows-Agent-Installation aus MSI;
- Zabbix-Quellen - laden Sie die Quelldateien herunter und folgen Sie den Anweisungen auf der Seite Zabbix Agent 2 unter Windows kompilieren.
Die Überwachungsfunktionen von Zabbix Agent 2 können mit ladbaren Plugins erweitert werden, die separat verfügbar sind. Weitere Details finden Sie unter Ladbare Plugins.
Weitere Informationen zur Installation von Zabbix Agent 2 (aus einem ZIP-Archiv) als Windows-Dienst finden Sie auf der Seite Zabbix Agent unter Microsoft Windows.
Optionen
Die folgenden Befehlszeilenparameter können mit Zabbix Agent 2 verwendet werden:
| Parameter | Beschreibung |
|---|---|
| UNIX- und Windows-Agent | |
-c --config <config-file> |
Pfad zur Konfigurationsdatei. Sie können diese Option verwenden, um eine Konfigurationsdatei anzugeben, die nicht die Standarddatei ist. |
-f --foreground |
Zabbix Agent im Vordergrund ausführen (Standard: true). |
-p --print |
Bekannte Datenpunkte ausgeben und beenden. Beachten Sie, dass Sie die Konfigurationsdatei angeben müssen, wenn Sie auch Ergebnisse von Benutzerparametern zurückgeben möchten (falls sie sich nicht am Standardpfad befindet). |
-t --test <item key> |
Den angegebenen Datenpunkt testen und beenden. Beachten Sie, dass Sie die Konfigurationsdatei angeben müssen, wenn Sie auch Ergebnisse von Benutzerparametern zurückgeben möchten (falls sie sich nicht am Standardpfad befindet). |
-T --test-config |
Konfigurationsdatei validieren und beenden. |
-h --help |
Hilfsinformationen ausgeben und beenden. |
-v --verbose |
Debugging-Informationen ausgeben. Verwenden Sie diese Option zusammen mit den Optionen -p und -t. |
-V --version |
Version und Lizenzinformationen des Agenten ausgeben. |
-R --runtime-control <option> |
Administrative Funktionen ausführen. Siehe Runtime-Steuerung. |
| Nur Windows-Agent | |
-m --multiple-agents |
Mehrere Agent-Instanzen verwenden (mit den Optionen -i, -d, -s, -x).Um Dienstnamen von Instanzen zu unterscheiden, enthält jeder Dienstname den Hostname-Wert aus der angegebenen Konfigurationsdatei. |
-S --startup-type <value> |
Den Starttyp des Zabbix Windows-Agent-Dienstes festlegen. Zulässige Werte:automatic - (Standard) den Dienst automatisch beim Windows-Start starten;delayed - den Start des Dienstes verzögern, nachdem die automatisch gestarteten Dienste ihren Start abgeschlossen haben;manual - den Dienst manuell starten (durch einen Benutzer oder eine Anwendung);disabled - den Dienst deaktivieren, sodass er nicht durch einen Benutzer oder eine Anwendung gestartet werden kann.Sie können diese Option zusammen mit der Option -i verwenden oder separat, um den Starttyp eines bereits installierten Dienstes zu ändern. |
-i --install |
Zabbix Windows-Agent als Dienst installieren. |
-d --uninstall |
Zabbix Windows-Agent-Dienst deinstallieren. |
-s --start |
Zabbix Windows-Agent-Dienst starten. |
-x --stop |
Zabbix Windows-Agent-Dienst stoppen. |
Spezifische Beispiele für die Verwendung von Befehlszeilenparametern:
- Alle integrierten Agent-Datenpunkte mit Werten ausgeben.
- Einen Benutzerparameter mit dem Schlüssel
mysql.pingtesten, der in der angegebenen Konfigurationsdatei definiert ist. - Einen Zabbix Agent-Dienst für Windows unter Verwendung des Standardpfads zur Konfigurationsdatei
C:\\Program Files\\Zabbix Agent 2\\zabbix_agent2.confinstallieren. - Den Starttyp eines installierten Zabbix Agent-Dienstes für Windows mithilfe der Konfigurationsdatei
zabbix_agent2.confändern, die sich im selben Ordner wie die Agent-Programmdatei befindet.
zabbix_agent2 --print
zabbix_agent2 -t "mysql.ping" -c /etc/zabbix/zabbix_agentd.conf
zabbix_agent2.exe -i
zabbix_agent2.exe -c zabbix_agent2.conf -S delayed
Runtime control
Runtime control bietet einige Optionen für die Fernsteuerung.
| Option | Description |
|---|---|
log_level_increase |
Log-Level erhöhen. |
log_level_decrease |
Log-Level verringern. |
metrics |
Verfügbare Metriken auflisten. |
version |
Agent-Version anzeigen. |
userparameter_reload |
Werte der Optionen UserParameter und Include aus der aktuellen Konfigurationsdatei neu laden. |
help |
Hilfsinformationen zur Laufzeitsteuerung anzeigen. |
Beispiele:
- Log-Level für Agent 2 erhöhen.
- Optionen der Laufzeitsteuerung ausgeben.
zabbix_agent2 -R log_level_increase
zabbix_agent2 -R help
Seit Zabbix 7.0.17 schreiben Befehle zur Laufzeitsteuerung von Agent 2 die Ausgabe nach stdout (Standardausgabe) statt nach stderr (Standardfehlerausgabe).
Konfigurationsdatei
Der Standardpfad zur Konfigurationsdatei ist:
- Unter UNIX ist der Standard
/usr/local/etc/zabbix_agent2.confoder der über Variablen zur Kompilierzeit festgelegte Wert--sysconfdiroder--prefix. - Unter Windows ist der Standard
C:\\Program Files\\Zabbix Agent 2\\zabbix_agent2.conf.
Wenn auf einem Host eine einzelne Instanz des Agent ausgeführt wird, kann sie die Standardkonfigurationsdatei oder eine auf der Befehlszeile angegebene Konfigurationsdatei verwenden. Bei mehreren Instanzen muss jede Agent-Instanz über ihre eigene Konfigurationsdatei verfügen (eine der Instanzen kann die Standardkonfigurationsdatei verwenden).
Die Konfigurationsparameter von Zabbix Agent 2 entsprechen größtenteils denen von Zabbix Agent, mit einigen Ausnahmen:
| Parameters | Description | |
|---|---|---|
| Zabbix agent 2-specific configuration parameters | ||
ControlSocket |
Der Pfad zum Laufzeit-Steuerungssocket. Zabbix Agent 2 verwendet einen Steuerungssocket für Laufzeitbefehle. | |
EnablePersistentBuffer,PersistentBufferFile,PersistentBufferPeriod |
Diese Parameter werden verwendet, um den persistenten Speicher auf Zabbix Agent 2 für aktive Datenpunkte zu konfigurieren. | |
ForceActiveChecksOnStart |
Legt fest, ob der Agent aktive Prüfungen unmittelbar nach dem Neustart ausführen oder gleichmäßig über die Zeit verteilen soll. | |
Plugins |
Plugins können eigene Parameter im Format Plugins.<Plugin name>.<Parameter>=<value> haben. Ein gängiger Plugin-Parameter ist System.Capacity, der das Limit für gleichzeitig ausführbare Prüfungen festlegt. |
|
StatusPort |
Der Port, auf dem Zabbix Agent 2 auf HTTP-Statusanfragen lauscht und eine Liste der konfigurierten Plugins sowie einiger interner Parameter anzeigt. | |
| Zabbix agent-specific configuration parameters not supported on Zabbix agent 2 | ||
AllowRoot,User |
Auf Zabbix Agent 2 nicht unterstützt, da keine Daemonisierung unterstützt wird. | |
EnableRemoteCommands |
Veraltet; stattdessen werden in beiden Agenten die Parameter AllowKey und DenyKey verwendet. |
|
ListenBacklog |
Wird in Zabbix Agent verwendet, um die maximale Anzahl ausstehender Verbindungen in der TCP-Warteschlange festzulegen. Auf Zabbix Agent 2 nicht unterstützt. | |
LoadModule,LoadModulePath |
Ladbare Module werden in Zabbix Agent 2 nicht unterstützt. | |
MaxLinesPerSecond,LogRemoteCommands |
In Zabbix Agent 2 werden stattdessen Plugins.Log.MaxLinesPerSecond und Plugins.SystemRun.LogRemoteCommands verwendet. |
|
StartAgents |
Dieser Parameter wird in Zabbix Agent verwendet, um die Parallelität passiver Prüfungen zu erhöhen oder diese zu deaktivieren. In Zabbix Agent 2 wird die Parallelität auf Plugin-Ebene konfiguriert und kann durch eine Kapazitätseinstellung begrenzt werden. Passive Prüfungen sind in Zabbix Agent 2 deaktiviert, wenn der Parameter Server nicht angegeben ist. |
|
Weitere Informationen finden Sie in den Optionen der Konfigurationsdatei für Zabbix agent2.
Exit-Codes
Zabbix Agent 2 kann auch mit älteren OpenSSL-Versionen (1.0.1, 1.0.2) kompiliert werden.
In diesem Fall stellt Zabbix Mutexes für das Locking in OpenSSL bereit.
Wenn das Sperren oder Entsperren eines Mutex fehlschlägt, wird eine Fehlermeldung in den Standardfehlerstrom (STDERR) ausgegeben und Agent 2 beendet sich mit dem Rückgabecode 2 bzw. 3.