VMware Tanzu-Logs erfassen
In diesem Dokument wird beschrieben, wie Sie VMware Tanzu-Logs mit dem Bindplane-Agent in Google Security Operations aufnehmen.
VMware Tanzu ist eine Kubernetes-Plattform, die Audit-Logs im JSON- und Syslog-Format für Kubernetes API-Server-Ereignisse, Ressourcenzugriff, Authentifizierungsentscheidungen und Konfigurationsänderungen generiert. Der Parser extrahiert Felder aus JSON-formatierten Audit-Logs und ordnet sie dem Unified Data Model (UDM) zu.
Hinweis
Prüfen Sie, ob folgende Voraussetzungen erfüllt sind:
- Eine Google SecOps-Instanz
- Windows Server 2016 oder höher oder Linux-Host mit
systemd - Netzwerkverbindung zwischen dem Bindplane-Agent und dem Tanzu Operations Manager
- Wenn Sie den Agent hinter einem Proxy ausführen, müssen die Firewallports gemäß den Anforderungen des Bindplane-Agents geöffnet sein.
- Privilegierter Zugriff auf VMware Tanzu
Authentifizierungsdatei für die Aufnahme in Google SecOps abrufen
- Melden Sie sich in der Google SecOps-Konsole an.
- Rufen Sie die SIEM-Einstellungen > Collection Agents auf.
- Laden Sie die Authentifizierungsdatei für die Aufnahme herunter.
Speichern Sie die Datei sicher auf dem System, auf dem BindPlane installiert wird.
Google SecOps-Kundennummer abrufen
- Melden Sie sich in der Google SecOps-Konsole an.
- Rufen Sie die SIEM-Einstellungen > Profile auf.
Kopieren und speichern Sie die Kunden-ID aus dem Bereich Organisationsdetails.
BindPlane-Agent installieren
Installieren Sie den Bindplane-Agent auf Ihrem Windows- oder Linux-Betriebssystem gemäß der folgenden Anleitung.
Fenstereinbau
- Öffnen Sie die Eingabeaufforderung oder PowerShell als Administrator.
Führen Sie dazu diesen Befehl aus:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietWarten Sie, bis die Installation abgeschlossen ist.
Überprüfen Sie die Installation mit folgendem Befehl:
sc query observiq-otel-collectorDer Dienst sollte als RUNNING (Wird ausgeführt) angezeigt werden.
Linux-Installation
- Öffnen Sie ein Terminal mit Root- oder Sudo-Berechtigungen.
Führen Sie dazu diesen Befehl aus:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shWarten Sie, bis die Installation abgeschlossen ist.
Überprüfen Sie die Installation mit folgendem Befehl:
sudo systemctl status observiq-otel-collectorDer Dienst sollte als aktiv (wird ausgeführt) angezeigt werden.
Zusätzliche Installationsressourcen
Weitere Installationsoptionen und Informationen zur Fehlerbehebung finden Sie in der Installationsanleitung für den Bindplane-Agent.
BindPlane-Agent zum Erfassen von Syslog-Daten und Senden an Google SecOps konfigurieren
Konfigurationsdatei suchen
Linux:
sudo nano /opt/observiq-otel-collector/config.yamlWindows:
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Konfigurationsdatei bearbeiten
Ersetzen Sie den gesamten Inhalt von
config.yamldurch die folgende Konfiguration:receivers: udplog: listen_address: "0.0.0.0:514" exporters: chronicle/vmware_tanzu: compression: gzip creds_file_path: '/etc/bindplane-agent/ingestion-auth.json' customer_id: '<customer_id>' endpoint: malachiteingestion-pa.googleapis.com log_type: VMWARE_TANZU raw_log_field: body service: pipelines: logs/vmware_tanzu_to_chronicle: receivers: - udplog exporters: - chronicle/vmware_tanzu
Konfigurationsparameter
Ersetzen Sie die folgenden Platzhalter:
Empfängerkonfiguration:
listen_address: IP-Adresse und Port, auf die gewartet werden soll:0.0.0.0, um alle Schnittstellen zu überwachen (empfohlen)- Port
514ist der Standard-Syslog-Port (erfordert Root unter Linux; verwenden Sie1514für Nicht-Root).
Exporter-Konfiguration:
creds_file_path: Vollständiger Pfad zur Datei für die Authentifizierung bei der Aufnahme:- Linux:
/etc/bindplane-agent/ingestion-auth.json - Windows:
C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
- Linux:
customer_id: Kunden-ID, die aus der Google SecOps Console kopiert wurdeendpoint: Regionale Endpunkt-URL:- USA:
malachiteingestion-pa.googleapis.com - Europa:
europe-malachiteingestion-pa.googleapis.com - Asien:
asia-southeast1-malachiteingestion-pa.googleapis.com - Eine vollständige Liste finden Sie unter Regionale Endpunkte.
- USA:
Konfigurationsdatei speichern
- Speichern Sie die Datei nach der Bearbeitung:
- Linux: Drücken Sie
Ctrl+O, dannEnterund dannCtrl+X. - Windows: Klicken Sie auf Datei > Speichern.
- Linux: Drücken Sie
Bindplane-Agent neu starten, um die Änderungen zu übernehmen
Führen Sie den folgenden Befehl aus, um den Bindplane-Agent unter Linux neu zu starten:
sudo systemctl restart observiq-otel-collectorPrüfen Sie, ob der Dienst ausgeführt wird:
sudo systemctl status observiq-otel-collectorLogs auf Fehler prüfen:
sudo journalctl -u observiq-otel-collector -f
Wählen Sie eine der folgenden Optionen aus, um den Bindplane-Agent unter Windows neu zu starten:
Eingabeaufforderung oder PowerShell als Administrator:
net stop observiq-otel-collector && net start observiq-otel-collectorServices-Konsole:
- Drücken Sie
Win+R, geben Sieservices.mscein und drücken Sie die Eingabetaste. - Suchen Sie nach observIQ OpenTelemetry Collector.
- Klicken Sie mit der rechten Maustaste und wählen Sie Neu starten aus.
Prüfen Sie, ob der Dienst ausgeführt wird:
sc query observiq-otel-collectorLogs auf Fehler prüfen:
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Drücken Sie
Syslog für VMware Tanzu konfigurieren
- Melden Sie sich in der Web-UI von Tanzu Operations Manager an.
- Wählen Sie Ihren Nutzernamen aus und klicken Sie dann auf Einstellungen.
- Wählen Sie Syslog aus.
- Klicken Sie auf Ja, um Systemprotokolle an einen Remote-Server zu senden.
- Geben Sie die folgenden Konfigurationsdetails an:
- Adresse: Geben Sie die IP-Adresse des BindPlane-Agents ein.
- Port: Geben Sie die Portnummer des Bindplane-Agents ein.
- Transport Protocol (Transportprotokoll): Wählen Sie je nach Konfiguration des Bindplane-Agents UDP oder TCP aus.
- Klicken Sie auf Speichern.
UDM-Zuordnungstabelle
| Logfeld | UDM-Zuordnung | Logik |
|---|---|---|
annotations.authorization.k8s.io/decision |
security_result.action |
Wenn die Annotation authorization.k8s.io/decision vorhanden ist, wird ihr Wert in Großbuchstaben umgewandelt. Wenn der Großbuchstabenwert „ALLOW“ ist, wird das UDM-Feld auf „ALLOW“ gesetzt. Andernfalls wird sie auf BLOCK gesetzt. |
annotations.authorization.k8s.io/reason |
security_result.description |
Wenn die Anmerkung authorization.k8s.io/reason vorhanden ist, wird ihr Wert (ohne doppelte Anführungszeichen) verwendet. |
apiVersion |
metadata.product_version |
Direkt zugeordnet. |
auditID |
metadata.product_log_id |
Direkt zugeordnet. |
kind |
metadata.product_event_type |
Direkt zugeordnet. |
objectRef.name |
target.resource.name |
Direkt zugeordnet. |
objectRef.namespace |
target.resource.attribute.labels.key, target.resource.attribute.labels.value |
key ist auf „namespace“ gesetzt und value wird aus objectRef.namespace übernommen. |
objectRef.resource |
target.resource.resource_subtype |
Direkt zugeordnet. |
objectRef.resourceVersion |
target.resource.attribute.labels.key, target.resource.attribute.labels.value |
key ist auf „resourceVersion“ gesetzt und value wird aus objectRef.resourceVersion übernommen. |
objectRef.uid |
target.resource.product_object_id |
Direkt zugeordnet. |
requestReceivedTimestamp/timestamp |
metadata.event_timestamp |
Der Parser versucht zuerst, requestReceivedTimestamp zu parsen. Wenn sie nicht vorhanden ist, wird das Feld timestamp verwendet, das aus dem Syslog-Präfix extrahiert wurde. |
requestURI |
target.url |
Direkt zugeordnet. |
responseStatus.code |
network.http.response_code |
Direkt zugeordnet, nachdem sie in eine Ganzzahl konvertiert wurde. |
sourceIPs |
principal.ip |
Alle IP-Adressen im sourceIPs-Array werden dem principal.ip-Array hinzugefügt. |
stage |
metadata.description |
Direkt zugeordnet. |
stageTimestamp |
metadata.collected_timestamp |
Direkt zugeordnet. |
user.groups |
principal.user.group_identifiers |
Alle Gruppen im user.groups-Array werden dem principal.user.group_identifiers-Array hinzugefügt. |
user.uid |
principal.user.userid |
Direkt zugeordnet. |
user.username |
principal.user.user_display_name |
Direkt zugeordnet. |
verb |
network.http.method |
Direkt zugeordnet, nachdem sie in Großbuchstaben umgewandelt wurden. Wird durch das Feld verb bestimmt. Wenn verb „CREATE“ ist, ist der Ereignistyp USER_RESOURCE_CREATION. Wenn verb „PATCH“ oder „UPDATE“ ist, ist der Ereignistyp USER_RESOURCE_UPDATE_CONTENT. Wenn verb „DELETE“ ist, ist der Ereignistyp USER_RESOURCE_DELETION. Andernfalls, wenn verb nicht leer ist, ist der Ereignistyp USER_RESOURCE_ACCESS. Wenn keine dieser Bedingungen erfüllt ist, wird der Ereignistyp auf GENERIC_EVENT festgelegt. Fest codiert auf „VMWARE_TANZU“. Fest codiert auf „VMWARE“. Fest codiert auf „VMWARE_TANZU“. Fest codiert auf „CLUSTER“. |
Benötigen Sie weitere Hilfe? Antworten von Community-Mitgliedern und Google SecOps-Experten erhalten