8 Erkennung von systemd-Diensten

Übersicht

Es ist möglich, systemd-Units (standardmäßig Services) mit Zabbix zu entdecken.

Item-Schlüssel

Der in der Discovery-Regel zu verwendende Datenpunkt ist

systemd.unit.discovery

Dieser Datenpunkt-Schlüssel wird nur von Zabbix agent 2 unterstützt.

Dieser Datenpunkt gibt ein JSON mit Informationen über systemd-Units zurück, zum Beispiel:

[{
    "{#UNIT.NAME}": "mysqld.service",
    "{#UNIT.DESCRIPTION}": "MySQL Server",
    "{#UNIT.LOADSTATE}": "loaded",
    "{#UNIT.ACTIVESTATE}": "active",
    "{#UNIT.SUBSTATE}": "running",
    "{#UNIT.FOLLOWED}": "",
    "{#UNIT.PATH}": "/org/freedesktop/systemd1/unit/mysqld_2eservice",
    "{#UNIT.JOBID}": 0,
    "{#UNIT.JOBTYPE}": "",
    "{#UNIT.JOBPATH}": "/",
    "{#UNIT.UNITFILESTATE}": "enabled"
}, {
    "{#UNIT.NAME}": "systemd-journald.socket",
    "{#UNIT.DESCRIPTION}": "Journal Socket",
    "{#UNIT.LOADSTATE}": "loaded",
    "{#UNIT.ACTIVESTATE}": "active",
    "{#UNIT.SUBSTATE}": "running",
    "{#UNIT.FOLLOWED}": "",
    "{#UNIT.PATH}": "/org/freedesktop/systemd1/unit/systemd_2djournald_2esocket",
    "{#UNIT.JOBID}": 0,
    "{#UNIT.JOBTYPE}": "",
    "{#UNIT.JOBPATH}": "/",
    "{#UNIT.UNITFILESTATE}": "enabled"
}]
Erkennung deaktivierter systemd-Units

Es ist auch möglich, deaktivierte systemd-Units zu erkennen. In diesem Fall werden im resultierenden JSON drei Makros zurückgegeben:

  • {#UNIT.PATH}
  • {#UNIT.ACTIVESTATE}
  • {#UNIT.UNITFILESTATE}.

Damit Datenpunkte und Auslöser aus Prototypen für deaktivierte systemd-Units erstellt werden, stellen Sie sicher, dass Sie einschränkende LLD-Filter für {#UNIT.ACTIVESTATE} und {#UNIT.UNITFILESTATE} anpassen (oder entfernen).

Unterstützte Makros

Die folgenden Makros werden für die Verwendung in der Erkennungsregel filter und in Vorlagen von Datenpunkten, Auslösern und Graphen unterstützt:

Macro Description
{#UNIT.NAME} Name der primären Einheit.
{#UNIT.DESCRIPTION} Für Menschen lesbare Beschreibung.
{#UNIT.LOADSTATE} Ladezustand (d. h. ob die Unit-Datei erfolgreich geladen wurde)
{#UNIT.ACTIVESTATE} Aktiver Zustand (d. h. ob die Unit derzeit gestartet ist oder nicht)
{#UNIT.SUBSTATE} Unterzustand (eine feiner granulierte Version des aktiven Zustands, die spezifisch für den Unit-Typ ist und die der aktive Zustand nicht ist)
{#UNIT.FOLLOWED} Unit, deren Zustand von dieser Unit verfolgt wird, falls vorhanden; andernfalls ein leerer String.
{#UNIT.PATH} Objektpfad der Unit.
{#UNIT.JOBID} Numerische Job-ID, wenn für die Job-Unit ein Job in der Warteschlange steht; andernfalls 0.
{#UNIT.JOBTYPE} Job-Typ.
{#UNIT.JOBPATH} Objektpfad des Jobs.
{#UNIT.UNITFILESTATE} Installationszustand der Unit-Datei.

Datenpunkt-Prototypen

Datenpunkt-Prototypen, die auf Basis der systemd-Service-Erkennung erstellt werden können, umfassen zum Beispiel:

  • Datenpunktname: {#UNIT.DESCRIPTION} active state info; Datenpunktschlüssel: systemd.unit.info["{#UNIT.NAME}"]
  • Datenpunktname: {#UNIT.DESCRIPTION} load state info; Datenpunktschlüssel: systemd.unit.info["{#UNIT.NAME}",LoadState]