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;
- Durch Plugins leicht erweiterbar zu sein, 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 den Zabbix Agent zu dienen und alle bisherigen Funktionen zu unterstützen.
Alle Metriken in Zabbix Agent 2 werden von Plugins erfasst.
Diese Funktionen sind spezifisch für Plugins:
- Geplante und flexible Intervalle für passive und aktive Prüfungen
- Verwaltung der Aufgabenwarteschlange unter Berücksichtigung von Zeitplan und Aufgabenparallelität
- Timeouts auf Plugin-Ebene
- Kompatibilitätsprüfung von Zabbix Agent 2 und seinen Plugins beim Start
Es gibt zwei Arten von Plugins:
Sie können auch Ihre eigenen Plugins erstellen.
Eigenständig erstellte Plugins müssen nicht in Agent 2 eingebaut sein. Sie können sie als ladbare Plugins hinzufügen und dadurch die Erstellung von Plugins für neue Metriken vereinfachen.
Ladbare Plugins können zur Laufzeit hinzugefügt werden, ohne Zabbix Agent 2 neu zu kompilieren.
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/planbare 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 im Ressourcenverbrauch zu vermeiden.
Um aktive Prüfungen, die kein Scheduling-Aktualisierungsintervall haben, unmittelbar nach dem Neustart des Agents auszuführen, setzen Sie den Parameter ForceActiveChecksOnStart (auf globaler Ebene) oder Plugins.<Plugin name>.System.ForceActiveChecksOnStart (wirkt nur auf bestimmte Plugin-Prüfungen) in der Konfigurationsdatei.
Ein Parameter auf Plugin-Ebene überschreibt 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, der OS-Distribution und der 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 durch ladbare Plugins erweitert werden, die separat verfügbar sind. Weitere Details finden Sie unter Loadable plugins.
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 zabbix_agent2-Binärdatei suchen und direkt ausführen; zum Beispiel:
zabbix_agent2
Agent 2 auf Windows-Systemen
Zabbix Agent 2 läuft als eigenständiger Prozess; 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 Agent herunter und folgen Sie den Anweisungen auf der Seite Installation des Windows-Agent aus MSI.
- Zabbix-Quellcode – laden Sie die Quelldateien herunter und folgen Sie den Anweisungen auf der Seite Erstellen von Zabbix Agent 2 unter Windows.
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.
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-Steuerung
Die Runtime-Steuerung bietet einige Optionen für die Fernsteuerung.
| Option | Beschreibung |
|---|---|
log_level_increase |
Erhöht den Log-Level. |
log_level_decrease |
Verringert den Log-Level. |
metrics |
Listet verfügbare Metriken auf. |
version |
Zeigt die Agent-Version an. |
userparameter_reload |
Lädt die Werte der Optionen UserParameter und Include aus der aktuellen Konfigurationsdatei neu. |
help |
Zeigt Hilfeinformationen zur Runtime-Steuerung an. |
Beispiele:
- Erhöhung des Log-Levels für Agent 2.
- Ausgabe der Optionen der Runtime-Steuerung.
zabbix_agent2 -R log_level_increase
zabbix_agent2 -R help
Konfigurationsdatei
Der Standardpfad zur Konfigurationsdatei ist:
- Unter UNIX ist der Standard
/usr/local/etc/zabbix_agent2.confoder der durch Variablen zur Kompilierzeit festgelegte Pfad--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 eine 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 |
Wird von 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. Wird von Zabbix Agent 2 nicht unterstützt. | |
LoadModule,LoadModulePath |
Ladbare Module werden von 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 sie 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.