AlgoSec Security Management-Protokolle erfassen
In diesem Dokument wird beschrieben, wie Sie AlgoSec Security Management-Logs mit dem Bindplane-Agent in Google Security Operations aufnehmen.
Die AlgoSec Security Management Suite (ASMS) bietet die Verwaltung von Netzwerksicherheitsrichtlinien für Firewalls, SDN und Cloud-Plattformen. Es umfasst Firewall Analyzer für die Risiko- und Compliance-Analyse, FireFlow für die Automatisierung des Änderungsmanagements und AppViz für die Sichtbarkeit der Anwendungsverbindungen.
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 den AlgoSec-Appliances
- 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 AlgoSec Firewall Analyzer, FireFlow und AppViz
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 der BindPlane-Agent 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 /etc/bindplane-agent/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/algosec: compression: gzip creds_file_path: '/etc/bindplane-agent/ingestion-auth.json' customer_id: '<customer_id>' endpoint: malachiteingestion-pa.googleapis.com log_type: ALGOSEC raw_log_field: body service: pipelines: logs/algosec_to_chronicle: receivers: - udplog exporters: - chronicle/algosec
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 Firewall Analyzer konfigurieren
- Melden Sie sich über SSH bei der AFA-Appliance an.
Wechseln Sie in das syslog-ng-Konfigurationsverzeichnis:
cd /etc/syslog-ngSichern Sie die vorhandene Konfiguration:
cp syslog-ng.conf syslog-ng.conf.origBearbeiten Sie die syslog-ng-Konfigurationsdatei:
vi syslog-ng.confFügen Sie die folgenden Zeilen hinzu, um den Remote-Syslog-Server zu definieren:
destination d_remote { udp("<BINDPLANE_IP>" port(514)); }; log { source(s_sys); destination(d_remote); };- Ersetzen Sie
<BINDPLANE_IP>durch die IP-Adresse des Bindplane-Agents.
- Ersetzen Sie
Speichern Sie die Datei und schließen Sie den Editor.
Starten Sie den syslog-ng-Dienst neu, um die Änderungen zu übernehmen:
service syslog-ng restartOptional: Syslog-Konfiguration prüfen:
- Gehen Sie zu Administration > Syslog Server Settings.
- Klicken Sie auf Konnektivität testen.
Syslog für FireFlow konfigurieren
- Melden Sie sich auf dem FireFlow-Computer als root an.
Öffnen Sie die Datei
/etc/syslog.confzur Bearbeitung.vi /etc/syslog.confFügen Sie der Datei die folgende Zeile hinzu:
local0.*@<BINDPLANE_IP>- Ersetzen Sie
<BINDPLANE_IP>durch die IP-Adresse des Bindplane-Agent-Servers.
- Ersetzen Sie
Syslog für AppViz konfigurieren
- Melden Sie sich über SSH auf der AppViz-Appliance an.
Wechseln Sie in das syslog-ng-Konfigurationsverzeichnis:
cd /etc/syslog-ngSichern Sie die vorhandene Konfiguration:
cp syslog-ng.conf syslog-ng.conf.origBearbeiten Sie die syslog-ng-Konfigurationsdatei:
vi syslog-ng.confFügen Sie Folgendes hinzu, um den Remote-Syslog-Server zu definieren:
destination d_remote { udp("<BINDPLANE_IP>" port(514)); }; log { source(s_sys); destination(d_remote); };- Ersetzen Sie
<BINDPLANE_IP>durch die IP-Adresse des Bindplane-Agents.
- Ersetzen Sie
Speichern Sie die Datei und schließen Sie den Editor.
Starten Sie den syslog-ng-Dienst neu, um die Änderungen zu übernehmen:
service syslog-ng restartSyslog-Konfiguration prüfen:
- Rufen Sie in der AppViz-Oberfläche Administration > Syslog Server Settings auf.
- Klicken Sie auf Konnektivität testen.
Syslog für An- und Abmeldeereignisse konfigurieren
- Melden Sie sich über SSH auf der ASMS-Appliance an.
Wechseln Sie in das syslog-ng-Konfigurationsverzeichnis:
cd /etc/syslog-ngSichern Sie die vorhandene Konfiguration:
cp syslog-ng.conf syslog-ng.conf.origBearbeiten Sie die syslog-ng-Konfigurationsdatei:
vi syslog-ng.confFügen Sie Folgendes hinzu, um den Remote-Syslog-Server zu definieren:
destination d_remote { udp("<BINDPLANE_IP>" port(514)); }; log { source(s_sys); destination(d_remote); };- Ersetzen Sie
<BINDPLANE_IP>durch die IP-Adresse des Bindplane-Agents.
- Ersetzen Sie
Speichern Sie die Datei und schließen Sie den Editor.
Starten Sie den syslog-ng-Dienst neu, um die Änderungen zu übernehmen:
service syslog-ng restart
UDM-Zuordnungstabelle
| Logfeld | UDM-Zuordnung | Logik |
|---|---|---|
by_user |
principal.user.user_display_name |
Der Wert des Felds by_user aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
collection_time |
metadata.event_timestamp |
Die Felder „seconds“ und „nanos“ werden kombiniert, um einen Zeitstempel zu erstellen. |
comm |
target.process.command_line |
Der Wert des Felds comm, der mit grok aus dem Feld desc extrahiert wird, wird diesem UDM-Feld zugewiesen. |
datetime |
metadata.event_timestamp |
Datum und Uhrzeit werden aus dem Rohlog extrahiert und zum Ausfüllen des Ereigniszeitstempels verwendet. |
desc |
metadata.description |
Der Wert des Felds desc aus dem Rohlog wird diesem UDM-Feld zugewiesen, wenn keine andere Beschreibung verfügbar ist. |
dest_ip |
target.ip |
Der Wert des Felds dest_ip aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
dest_port |
target.port |
Der Wert des Felds dest_port aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
details |
security_result.summary |
Der Wert des Felds details aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
device |
principal.asset.hostname |
Der Wert des Felds device aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
dst_ip |
target.ip |
Der Wert des Felds dst_ip aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
dst_port |
target.port |
Der Wert des Felds dst_port aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
event_id |
metadata.product_event_type |
Der Wert des Felds event_id aus dem Rohlog wird diesem UDM-Feld zugewiesen. Sie wird auch in der Parserlogik verwendet, um metadata.event_type und andere Felder zu bestimmen. |
event_name |
metadata.product_event_type |
Der Wert des Felds event_name aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
firewall |
target.hostname |
Der Wert des Felds firewall aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
host |
principal.hostname |
Der Wert des Felds host aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
host_type |
principal.asset.category |
Der Wert des Felds host_type aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
iporhost |
principal.ip/principal.hostname/target.ip/target.hostname/observer.ip/observer.hostname |
Wenn der Wert eine IP-Adresse ist, wird er je nach Protokollquelle und Ereignistyp principal.ip,target.ip, oder observer.ip zugeordnet. Wenn es sich um einen Hostnamen handelt, wird er principal.hostname,target.hostname, oder observer.hostname zugeordnet. |
IP |
principal.ip |
Der Wert des Felds IP aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
kv_data |
security_result.summary |
Der Wert des Felds kv_data aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
log_type |
metadata.log_type |
Hartcodiert auf ALGOSEC. |
metric |
security_result.action_details |
Der Wert des Felds metric aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
msg |
security_result.summary/security_result.description |
Der Wert des Felds msg aus dem Rohlog wird verwendet, um je nach Kontext entweder die Zusammenfassung oder die Beschreibung des Sicherheitsergebnisses zu füllen. Sie wird auch für die Felder extractrisk_level,risk_count,risk_code, und risk_title verwendet. |
pid |
target.process.pid |
Der Wert des Felds pid, der mit grok aus dem Feld desc extrahiert wird, wird diesem UDM-Feld zugewiesen. |
product |
metadata.product_name |
Der Wert des Felds product aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
report |
security_result.description |
Der Wert des Felds report aus dem Rohlog ist in der Beschreibung des Sicherheitsergebnisses enthalten. |
report_data.Device IP |
target.ip |
Der Wert des Felds Device IP aus den geparsten JSON-Daten wird diesem UDM-Feld zugewiesen. |
report_data.Highest Risk Level |
security_result.description |
Der Wert des Felds Highest Risk Level aus den geparsten JSON-Daten ist in der Beschreibung des Sicherheitsergebnisses enthalten. Außerdem wird damit der Schweregrad des Sicherheitsergebnisses bestimmt. |
report_data.Security Rating Score |
security_result.description |
Der Wert des Felds Security Rating Score aus den geparsten JSON-Daten ist in der Beschreibung des Sicherheitsergebnisses enthalten. |
Requestor.Email |
principal.user.email_addresses |
Der Wert des Felds Email im Request-Objekt aus den geparsten JSON-Daten wird diesem UDM-Feld zugewiesen. |
Requestor.Name |
principal.user.user_display_name |
Der Wert des Felds Name im Requestor-Objekt aus den geparsten JSON-Daten wird diesem UDM-Feld zugewiesen. |
RequestType |
target.resource.attribute.labels |
Der Wert des Felds RequestType aus dem Rohlog wird als Label zur Zielressource hinzugefügt. |
risk_title |
security_result.summary |
Der Wert des Felds risk_title aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
src_ip |
principal.ip |
Der Wert des Felds src_ip aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
src_port |
principal.port |
Der Wert des Felds src_port aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
status |
security_result.description/security_result.action_details |
Der Wert des Felds status aus dem Rohlog ist je nach Kontext in der Beschreibung des Sicherheitsergebnisses oder in den Aktionsdetails enthalten. Außerdem wird damit der Schweregrad des Sicherheitsergebnisses bestimmt. |
target_app |
target.application |
Der Wert des Felds target_app aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
TemplateName |
metadata.description |
Der Wert des Felds TemplateName aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
url |
security_result.url_back_to_product |
Der Wert des Felds url aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
user |
principal.user.userid |
Der Wert des Felds user aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
vendor |
metadata.vendor_name |
Der Wert des Felds vendor aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
version |
metadata.product_version |
Der Wert des Felds version aus dem Rohlog wird diesem UDM-Feld zugewiesen. |
WorkFlow |
target.resource.attribute.labels |
Der Wert des Felds WorkFlow aus dem Rohlog wird als Label zur Zielressource hinzugefügt. |
(Parser Logic) |
extensions.auth.type |
Hartcodiert auf MACHINE. |
(Parser Logic) |
security_result.action |
Wird anhand von event_id und anderen Feldern bestimmt. Normalerweise auf ALLOW or BLOCK gesetzt. |
(Parser Logic) |
security_result.category |
Für Firewall Analyzer-Ereignisse ist POLICY_VIOLATION hartcodiert. |
(Parser Logic) |
security_result.description |
Wird auf Grundlage anderer Felder erstellt und liefert Kontext und Details zum Ereignis. |
(Parser Logic) |
security_result.severity |
Wird anhand von event_id,msg, und anderen Feldern bestimmt. Wird in der Regel auf LOW,MEDIUM, oder „HIGH“ festgelegt. |
(Parser Logic) |
metadata.event_type |
Wird anhand von event_id und anderen Feldern bestimmt. Beispiele sind USER_LOGIN,USER_LOGOUT,USER_RESOURCE_ACCESS,GENERIC_EVENT,STATUS_UNCATEGORIZED,SCAN_HOST,NETWORK_CONNECTION, und STATUS_UPDATE. |
Benötigen Sie weitere Hilfe? Antworten von Community-Mitgliedern und Google SecOps-Experten erhalten