ExtraHop RevealX-Logs erfassen
In diesem Dokument wird beschrieben, wie Sie ExtraHop RevealX-Logs mit Bindplane in Google Security Operations aufnehmen. Der Parser extrahiert Felder aus JSON- und Syslog-formatierten Logs. Dabei werden Grok-Muster und bedingte Logik verwendet, um verschiedene Logformate zu verarbeiten. Extrahierte Felder werden dem UDM zugeordnet und die Daten werden mit sicherheitsrelevanten Informationen wie Schweregrad und Kategorien angereichert. Der Parser verarbeitet auch bestimmte ExtraHop-Ereignistypen wie DNS-Rebinding, Kerberos-Authentifizierungsfehler und RDP-Verbindungen und wendet für jeden Typ eine spezielle Parsing-Logik an.
Hinweise
Prüfen Sie, ob folgende Voraussetzungen erfüllt sind:
- Google SecOps-Instanz
- Windows 2016 oder höher oder ein Linux-Host mit
systemd
- Wenn die Ausführung hinter einem Proxy erfolgt, müssen die Firewallports geöffnet sein.
- Privilegierter Zugriff auf ExtraHop Reveal X
Authentifizierungsdatei für die Aufnahme in Google SecOps abrufen
- Melden Sie sich in der Google SecOps-Konsole an.
- Rufen Sie 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 > „Profil“ 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" /quiet
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.sh
Zusätzliche Installationsressourcen
Weitere Installationsoptionen finden Sie im Installationsleitfaden.
BindPlane-Agent zum Erfassen von Syslog-Daten und Senden an Google SecOps konfigurieren
- Rufen Sie die Konfigurationsdatei auf:
- Suchen Sie die Datei
config.yaml
. Normalerweise befindet sie sich unter Linux im Verzeichnis/etc/bindplane-agent/
oder unter Windows im Installationsverzeichnis. - Öffnen Sie die Datei mit einem Texteditor (z. B.
nano
,vi
oder Notepad).
- Suchen Sie die Datei
Bearbeiten Sie die Datei
config.yaml
so:receivers: udplog: # Replace the port and IP address as required listen_address: "0.0.0.0:514" exporters: chronicle/chronicle_w_labels: compression: gzip # Adjust the path to the credentials file you downloaded in Step 1 creds_file_path: '/path/to/ingestion-authentication-file.json' # Replace with your actual customer ID from Step 2 customer_id: <customer_id> endpoint: malachiteingestion-pa.googleapis.com # Add optional ingestion labels for better organization log_type: 'EXTRAHOP' raw_log_field: body ingestion_labels: service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels
- Ersetzen Sie den Port und die IP-Adresse nach Bedarf in Ihrer Infrastruktur.
- Ersetzen Sie
<customer_id>
durch die tatsächliche Kunden-ID. - Aktualisieren Sie
/path/to/ingestion-authentication-file.json
auf den Pfad, in dem die Authentifizierungsdatei im Abschnitt Google SecOps-Aufnahmeauthentifizierungsdatei abrufen gespeichert wurde.
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 bindplane-agent
Wenn Sie den Bindplane-Agent unter Windows neu starten möchten, können Sie entweder die Konsole Dienste verwenden oder den folgenden Befehl eingeben:
net stop BindPlaneAgent && net start BindPlaneAgent
ExtraHop-Syslog konfigurieren
- Melden Sie sich mit
https://<extrahop-hostname-or-IP-address>/admin
in der ExtraHop-Administration an. - Rufen Sie Status und Diagnose > Audit-Log auf.
- Klicken Sie auf Syslog-Einstellungen konfigurieren.
- Geben Sie die folgenden Konfigurationsdetails an:
- Ziel: Geben Sie die IP-Adresse des BindPlane-Agents ein.
- Protocol (Protokoll): Wählen Sie je nach Bindplane-Konfiguration UDP oder TCP aus.
- Port: Geben Sie die Portnummer des Bindplane-Agents ein.
- Klicken Sie auf Testeinstellungen.
- Klicken Sie auf Speichern.
UDM-Zuordnungstabelle
Logfeld | UDM-Zuordnung | Logik |
---|---|---|
alert_name |
security_result.summary |
Der Wert von alert_name aus dem Rohlog wird security_result.summary zugeordnet. |
answers[].data |
network.dns.answers[].data |
Der Wert von data für jedes Element im answers -Array aus dem Rohlog wird dem Feld data des entsprechenden Elements im network.dns.answers -Array zugeordnet. |
answers[].name |
network.dns.answers[].name |
Der Wert von name für jedes Element im answers -Array aus dem Rohlog wird dem Feld name des entsprechenden Elements im network.dns.answers -Array zugeordnet. |
answers[].ttl |
network.dns.answers[].ttl |
Der Wert von ttl für jedes Element im answers -Array aus dem Rohlog wird dem Feld ttl des entsprechenden Elements im network.dns.answers -Array zugeordnet. |
answers[].typeNum |
network.dns.answers[].type |
Der Wert von typeNum für jedes Element im answers -Array aus dem Rohlog wird dem Feld type des entsprechenden Elements im network.dns.answers -Array zugeordnet. |
client_ip |
principal.ip |
Der Wert von client_ip aus dem Rohlog wird principal.ip zugeordnet. |
cn1 |
security_result.rule_labels[].value |
Der Wert von cn1 aus dem Rohlog wird als Wert für ein security_result.rule_labels -Element mit dem Schlüssel „Detection ID“ verwendet. |
cn2 |
security_result.detection_fields[].value |
Der Wert von cn2 aus dem Rohlog wird als Wert für ein security_result.detection_fields -Element mit dem Schlüssel „riskscore“ verwendet. |
cs1 |
security_result.rule_name |
Der Wert von cs1 aus dem Rohlog wird security_result.rule_name zugeordnet. |
cs2 |
security_result.category_details[] |
Der Wert von cs2 aus dem Rohlog wird als Element dem security_result.category_details -Array hinzugefügt. |
description |
metadata.description |
Der Wert von description aus dem Rohlog wird nach der Verarbeitung (Entfernen von Zeilenumbruchzeichen und Backslashes) metadata.description zugeordnet. In einigen Fällen können andere Felder aus dem Rohlog zu diesem Feld beitragen oder es überschreiben. |
details |
principal.resource.resource_subtype , security_result.summary , principal.ip |
Das Feld details wird geparst. Der mit dem Schlüssel „facility“ verknüpfte Wert wird principal.resource.resource_subtype zugeordnet. Der mit dem Schlüssel „details“ verknüpfte Wert wird security_result.summary zugeordnet. Der mit dem Schlüssel „src_ip“ verknüpfte Wert wird principal.ip zugeordnet. |
dst |
target.ip oder target.mac |
Der Wert von dst aus dem Rohlog wird target.ip zugeordnet, wenn es sich um eine IP-Adresse handelt, oder target.mac , wenn es sich um eine MAC-Adresse handelt. |
dst_ip |
target.ip |
Der Wert von dst_ip aus dem Rohlog wird target.ip zugeordnet. |
eh_event |
metadata.event_type , network.application_protocol |
Wenn eh_event „dns“ ist, wird metadata.event_type auf NETWORK_DNS und network.application_protocol auf DNS festgelegt. Wenn eh_event „RDP“ ist, wird metadata.event_type auf NETWORK_CONNECTION und network.application_protocol auf RDP festgelegt. |
event_id |
metadata.product_event_type |
Der Wert von event_id aus dem Rohlog wird metadata.product_event_type zugeordnet. |
facility |
principal.resource.resource_subtype |
Der Wert von facility aus dem Rohlog wird principal.resource.resource_subtype zugeordnet. |
ipaddr |
principal.ip |
Der Wert von ipaddr aus dem Rohlog wird principal.ip zugeordnet. |
jsonPayload.description |
metadata.product_event_type , principal.hostname , principal.asset.hostname , security_result.summary |
Das Feld jsonPayload.description wird als JSON geparst. Das Feld „operation“ wird metadata.product_event_type zugeordnet. Das Feld „event“ (nach dem Entfernen von „Audit Log“) wird principal.hostname und principal.asset.hostname zugeordnet. Das Feld „details“ ist security_result.summary zugeordnet. |
jsonPayload.event |
metadata.product_event_type , principal.hostname , principal.asset.hostname |
Der Wert von jsonPayload.event aus dem Rohlog (nach dem Entfernen von „Audit-Log“) wird metadata.product_event_type , principal.hostname und principal.asset.hostname zugeordnet. |
jsonPayload.id |
metadata.product_log_id |
Der Wert von jsonPayload.id aus dem Rohlog wird metadata.product_log_id zugeordnet. |
macaddr |
principal.mac |
Der Wert von macaddr aus dem Rohlog wird principal.mac zugeordnet. |
name |
metadata.description |
Der Wert von name aus dem Rohlog wird metadata.description zugeordnet. |
object_id |
target.resource.product_object_id |
Der Wert von object_id aus dem Rohlog wird target.resource.product_object_id zugeordnet. |
object_name |
target.resource.name |
Der Wert von object_name aus dem Rohlog wird target.resource.name zugeordnet. |
object_type |
target.resource.resource_type |
Der Wert von object_type aus dem Rohlog (in Großbuchstaben umgewandelt) wird target.resource.resource_type zugeordnet. |
operation |
metadata.product_event_type |
Der Wert von operation aus dem Rohlog wird metadata.product_event_type zugeordnet. |
priority |
security_result.severity , security_result.severity_details |
Wenn priority „notice“ ist, wird security_result.severity auf MEDIUM und security_result.severity_details auf den Wert von priority gesetzt. |
product_event_type |
metadata.product_event_type |
Der Wert von product_event_type aus dem Rohlog wird metadata.product_event_type zugeordnet. Außerdem wird damit der metadata.event_type -Wert und andere Felder bestimmt. |
qname |
network.dns.questions[].name |
Der Wert von qname aus dem Rohlog wird dem Feld name eines network.dns.questions -Elements zugeordnet. |
qname_or_host |
intermediary.hostname |
Der Wert von qname_or_host aus dem Rohlog wird intermediary.hostname zugeordnet. |
qtype |
network.dns.questions[].type |
Der Wert von qtype aus dem Rohlog wird dem Feld type eines network.dns.questions -Elements zugeordnet. Dabei wird die Stringdarstellung entsprechend den DNS-Eintragstypen in das numerische Äquivalent konvertiert. |
resource.labels.project_id |
target.resource.attribute.labels[].value |
Der Wert von resource.labels.project_id aus dem Rohlog wird als Wert für ein target.resource.attribute.labels -Element mit dem Schlüssel „Project id“ verwendet. |
resource.type |
target.resource.resource_subtype |
Der Wert von resource.type aus dem Rohlog wird target.resource.resource_subtype zugeordnet. |
rdp_record.clientBuild |
metadata.product_version |
Der Wert von rdp_record.clientBuild aus dem Rohlog wird metadata.product_version zugeordnet. |
rdp_record.clientBytes |
network.sent_bytes |
Der Wert von rdp_record.clientBytes aus dem Rohlog wird network.sent_bytes zugeordnet. |
rdp_record.clientName |
principal.hostname |
Der Wert von rdp_record.clientName aus dem Rohlog wird principal.hostname zugeordnet. |
rdp_record.clientPort |
principal.port |
Der Wert von rdp_record.clientPort aus dem Rohlog wird principal.port zugeordnet. |
rdp_record.cookie |
principal.user.userid |
Der Wert von rdp_record.cookie (nach dem Entfernen von „mstshash=“) aus dem Rohlog wird principal.user.userid zugeordnet. |
rdp_record.proto |
network.ip_protocol |
Der Wert von rdp_record.proto aus dem Rohlog wird network.ip_protocol zugeordnet, wobei „TCP“ in „TCP“ und „UDP“ in „UDP“ konvertiert wird. |
rdp_record.selectedProtocol |
security_result.description |
Der Wert von rdp_record.selectedProtocol aus dem Rohlog wird security_result.description zugeordnet. |
rdp_record.serverBytes |
network.received_bytes |
Der Wert von rdp_record.serverBytes aus dem Rohlog wird network.received_bytes zugeordnet. |
rdp_record.serverPort |
target.port |
Der Wert von rdp_record.serverPort aus dem Rohlog wird target.port zugeordnet. |
rt |
metadata.event_timestamp |
Der Wert von rt aus dem Rohlog wird als Zeitstempel geparst und metadata.event_timestamp zugeordnet. |
severity |
security_result.severity , security_result.severity_details , event.idm.is_alert , event.idm.is_significant |
Der Wert von severity wird security_result.severity_details zugeordnet. Er wird auch verwendet, um die Werte von security_result.severity , event.idm.is_alert und event.idm.is_significant zu bestimmen. |
src |
principal.ip oder principal.mac |
Der Wert von src aus dem Rohlog wird principal.ip zugeordnet, wenn es sich um eine IP-Adresse handelt, oder principal.mac , wenn es sich um eine MAC-Adresse handelt. |
src_ip |
principal.ip oder principal.mac |
Der Wert von src_ip aus dem Rohlog wird principal.ip zugeordnet, wenn es sich um eine IP-Adresse handelt, oder principal.mac , wenn es sich um eine MAC-Adresse handelt. |
summary |
security_result.summary |
Der Wert von summary aus dem Rohlog wird security_result.summary zugeordnet. |
ts |
metadata.event_timestamp |
Der Wert von ts aus dem Rohlog wird als Zeitstempel geparst und metadata.event_timestamp zugeordnet. |
user |
principal.user.userid |
Der Wert von user aus dem Rohlog wird principal.user.userid zugeordnet. |
(–) | metadata.log_type |
Immer auf „EXTRAHOP“ festgelegt. |
(–) | metadata.vendor_name |
Immer auf „EXTRAHOP“ festgelegt. |
(–) | metadata.product_name |
Immer auf „EXTRAHOP“ festgelegt. |
(–) | security_result.severity |
Standardmäßig auf CRITICAL festgelegt oder basierend auf dem Wert von severity oder priority . |
(–) | event.idm.is_alert |
Wird auf true gesetzt, wenn security_result.severity „HIGH“ oder „CRITICAL“ ist. |
(–) | event.idm.is_significant |
Wird auf true gesetzt, wenn security_result.severity „HIGH“ oder „CRITICAL“ ist. |
(–) | metadata.event_type |
Wird anhand der Werte anderer Felder wie eh_event , product_event_type , has_principal und dst bestimmt. Die Standardeinstellung ist GENERIC_EVENT . |
(–) | network.application_protocol |
Auf DNS festgelegt, wenn eh_event „dns“ ist oder message „DNS Rebinding“ enthält. Wird auf RDP gesetzt, wenn eh_event gleich „RDP“ ist. |
(–) | security_result.rule_labels[].key |
Auf „Detection ID“ (Erkennungs-ID) festgelegt für das aus cn1 abgeleitete Regellabel. |
(–) | security_result.detection_fields[].key |
Auf „riskscore“ für das aus cn2 abgeleitete Erkennungsfeld festgelegt. |
(–) | principal.user.attribute.roles[].type |
Wird auf SERVICE_ACCOUNT gesetzt, wenn user_name vorhanden ist. |
(–) | extensions.auth.type |
Auf SSO festlegen, wenn product_event_type „Kerberos Client Auth Errors“ ist. |
(–) | extensions.auth.mechanism |
Wird auf USERNAME_PASSWORD gesetzt, wenn product_event_type „Unsafe LDAP Authentication“ (Unsichere LDAP-Authentifizierung) oder „Kerberos Client Auth Errors“ (Kerberos-Client-Authentifizierungsfehler) ist. |
(–) | security_result.category |
Wird auf NETWORK_SUSPICIOUS gesetzt, wenn product_event_type „DNS Internal Reverse Lookup Scan“ ist oder „Inbound Suspicious Connections“ enthält. Auf NETWORK_MALICIOUS festlegen, wenn product_event_type „Anfrage an externen Datenbankserver“ ist. |
(–) | network.http.response_code |
Wird basierend auf dem status_code festgelegt, der aus product_event_type extrahiert wird, wenn er dem Muster „HTTP Server %{INT:status_code} %{GREEDYDATA}“ entspricht. |
jsonPayload.cs1 |
security_result.detection_fields[].value |
Der Wert von jsonPayload.cs1 aus dem Rohlog wird als Wert für ein security_result.detection_fields -Element verwendet. |
jsonPayload.cn1 |
security_result.detection_fields[].value |
Der Wert von jsonPayload.cn1 aus dem Rohlog wird als Wert für ein security_result.detection_fields -Element verwendet. |
jsonPayload.cn2 |
security_result.detection_fields[].value |
Der Wert von jsonPayload.cn2 aus dem Rohlog wird als Wert für ein security_result.detection_fields -Element verwendet. |
jsonPayload.cs1Label , jsonPayload.cn1Label , jsonPayload.cn2Label |
security_result.detection_fields[].key |
Diese Felder aus dem Rohlog werden als Schlüssel für die entsprechenden Elemente in security_result.detection_fields verwendet. |
jsonPayload.src |
principal.ip |
Der Wert von jsonPayload.src aus dem Rohlog wird principal.ip zugeordnet. |
jsonPayload.dst |
target.ip |
Der Wert von jsonPayload.dst aus dem Rohlog wird target.ip zugeordnet. |
Benötigen Sie weitere Hilfe? Antworten von Community-Mitgliedern und Google SecOps-Experten erhalten