收集 VMware Horizon 記錄

支援的國家/地區:

本文說明如何使用 Bindplane,將 Omnissa Horizon (舊稱 VMware Horizon) 記錄檔擷取至 Google Security Operations。剖析器會先使用規則運算式 (grok 模式) 從原始系統記錄訊息中擷取欄位,接著,系統會將擷取的欄位對應至 Chronicle UDM 結構定義中的對應欄位,並將資料正規化及結構化,以供分析。

事前準備

請確認您已完成下列事前準備事項:

  • Google SecOps 執行個體
  • Windows 2016 以上版本,或搭載 systemd 的 Linux 主機
  • 如果透過 Proxy 執行,請確認防火牆通訊埠已開啟
  • Omnissa Horizon 8 的特殊存取權

取得 Google SecOps 擷取驗證檔案

  1. 登入 Google SecOps 控制台。
  2. 依序前往「SIEM 設定」>「收集代理程式」
  3. 下載擷取驗證檔案。將檔案安全地儲存在要安裝 Bindplane 的系統上。

取得 Google SecOps 客戶 ID

  1. 登入 Google SecOps 控制台。
  2. 依序前往「SIEM 設定」>「設定檔」
  3. 複製並儲存「機構詳細資料」專區中的客戶 ID

安裝 Bindplane 代理程式

請按照下列操作說明,在 Windows 或 Linux 作業系統上安裝 Bindplane 代理程式。

Windows 安裝

  1. 以系統管理員身分開啟「命令提示字元」或「PowerShell」
  2. 執行下列指令:

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    

Linux 安裝

  1. 開啟具有根層級或 sudo 權限的終端機。
  2. 執行下列指令:

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    

其他安裝資源

如需其他安裝選項,請參閱安裝指南

設定 Bindplane 代理程式,擷取系統記錄檔並傳送至 Google SecOps

  1. 存取設定檔:
    • 找出 config.yaml 檔案。通常位於 Linux 的 /etc/bindplane-agent/ 目錄,或 Windows 的安裝目錄。
    • 使用文字編輯器 (例如 nanovi 或記事本) 開啟檔案。
  2. 按照下列方式編輯 config.yaml 檔案:

    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: 'VMWARE_HORIZON'
            raw_log_field: body
            ingestion_labels:
    
    service:
        pipelines:
            logs/source0__chronicle_w_labels-0:
                receivers:
                    - udplog
                exporters:
                    - chronicle/chronicle_w_labels
    
    • 視基礎架構需求,替換通訊埠和 IP 位址。
    • <customer_id> 替換為實際的客戶 ID。
    • /path/to/ingestion-authentication-file.json 更新為「取得 Google SecOps 擷取驗證檔案」一節中儲存驗證檔案的路徑。

重新啟動 Bindplane 代理程式,以套用變更

  • 如要在 Linux 中重新啟動 Bindplane 代理程式,請執行下列指令:

    sudo systemctl restart bindplane-agent
    
  • 如要在 Windows 中重新啟動 Bindplane 代理程式,可以使用「服務」控制台,或輸入下列指令:

    net stop BindPlaneAgent && net start BindPlaneAgent
    

為 Omnissa Horizon (舊稱 VMware Horizon) 設定 Syslog

  1. 登入 Onmissa Horizon 網頁版 UI,
  2. 依序前往「設定」>「活動設定」
  3. 在「傳送至系統記錄伺服器」部分中,按一下「新增」
  4. 輸入 Bindplane 代理程式 IP 位址和通訊埠編號 (請務必將 Bindplane 通訊協定設為 UDP)。
  5. 按一下 [儲存]

UDM 對應表

記錄欄位 UDM 對應 邏輯
ActionId metadata.product_log_id 原始記錄中的「ActionId」值會對應至「metadata.product_log_id」。
admin_domain principal.administrative_domain 原始記錄中的「admin_domain」值會對應至「principal.administrative_domain」。
BrokerName principal.hostname 原始記錄中的「BrokerName」值會對應至「principal.hostname」。
BrokerSessionId network.session_id 原始記錄中的「BrokerSessionId」值會對應至「network.session_id」。
ClientIpAddress principal.ip 原始記錄中的「ClientIpAddress」值會對應至「principal.ip」。
CurrentSessionLength network.session_duration.seconds 原始記錄中的「CurrentSessionLength」值會轉換為整數,然後對應至「network.session_duration.seconds」。
description metadata.description 原始記錄中的「description」值會對應至「metadata.description」。
DesktopDisplayName principal.hostname 原始記錄中的「DesktopDisplayName」值會對應至「principal.hostname」。
EventType metadata.product_event_type 原始記錄中的「EventType」值會對應至「metadata.product_event_type」。
ForwardedClientIpAddress principal.nat_ip 原始記錄中的「ForwardedClientIpAddress」值會對應至「principal.nat_ip」。
GlobalEntitlementName target.user.group_identifiers 原始記錄中的「GlobalEntitlementName」值會對應至「target.user.group_identifiers」。
host principal.hostname 原始記錄中的「host」值會對應至「principal.hostname」。
MachineDnsName principal.url 原始記錄中的「MachineDnsName」值會對應至「principal.url」。
MachineName intermediary.hostname 原始記錄中的「MachineName」值會對應至「intermediary.hostname」。
Module additional.fields 系統會將原始記錄中「Module」的值為「Module」的鍵,新增至「additional.fields」陣列。
pid principal.process.pid 原始記錄中的「pid」值會對應至「principal.process.pid」。
PoolId additional.fields 系統會將「PoolId」鍵 (值為原始記錄中的「PoolId」) 新增至「additional.fields」陣列。
program principal.application 原始記錄中的「program」值會對應至「principal.application」。
SessionType additional.fields 系統會將「SessionType」鍵和原始記錄中的「SessionType」值新增至「additional.fields」陣列。
Severity security_result.severity 原始記錄中的「嚴重程度」值會轉換為大寫,對應至一般 Chronicle 嚴重程度,然後對應至「security_result.severity」。
timestamp metadata.event_timestamp 原始記錄中的「timestamp」值會轉換為 Chronicle 格式,然後對應至「metadata.event_timestamp」。
UserDisplayName target.user.user_display_name 原始記錄中的「UserDisplayName」值會對應至「target.user.user_display_name」。
UserName target.user.userid 原始記錄中的「UserName」值會對應至「target.user.userid」。
UserSID target.user.windows_sid 原始記錄中的「UserSID」值會對應至「target.user.windows_sid」。
ViewApiMethodName additional.fields 系統會將原始記錄中的「ViewApiMethodName」鍵和「ViewApiMethodName」值新增至「additional.fields」陣列。
ViewApiServiceName additional.fields 系統會將原始記錄中的「ViewApiServiceName」鍵和值新增至「additional.fields」陣列。
extensions.auth.type 如果「EventType」欄位是「ADMIN_USERLOGGEDOUT」、「AGENT_CONNECTED」、「AGENT_DISCONNECTED」、「AGENT_ENDED」、「AGENT_PENDING」、「AGENT_PENDING_EXPIRED」、「AGENT_RECONNECTED」、「BROKER_DESKTOP_REQUEST」、「BROKER_LMV_REMOTE_POD_DESKTOP_LAUNCH」、「BROKER_MACHINE_ALLOCATED」、「BROKER_USER_AUTHFAILED_BAD_USER_PASSWORD」、「BROKER_USER_LOCK_SSO」、「BROKER_USERLOGGEDIN」、「BROKER_USERLOGGEDOUT」、「VLSI_USERLOGGEDIN」、「VLSI_INSUFFICIENT_PERMISSION」、「VLSI_USERLOGGEDIN_REST」、「TIMING_PROFILER_TUNNEL_CONNECTION」、「TIMING_PROFILER_GET_LAUNCH_ITEMS」、「TIMING_PROFILER_USER_AUTHENTICATION」其中之一,則值會設為「SSO」。
metadata.event_type 這個值是由「EventType」欄位決定。如果「EventType」是「ADMIN_USERLOGGEDOUT」、「AGENT_DISCONNECTED」、「AGENT_ENDED」、「AGENT_PENDING_EXPIRED」、「BROKER_USER_LOCK_SSO」或「BROKER_USERLOGGEDOUT」,則「metadata.event_type」為「USER_LOGOUT」。如果「EventType」是「AGENT_CONNECTED」、「AGENT_PENDING」、「AGENT_RECONNECTED」、「BROKER_USERLOGGEDIN」、「VLSI_USERLOGGEDIN」、「VLSI_INSUFFICIENT_PERMISSION」或「VLSI_USERLOGGEDIN_REST」其中之一,則「metadata.event_type」為「USER_LOGIN」。如果「EventType」是「TIMING_PROFILER_GET_LAUNCH_ITEMS」,則「metadata.event_type」為「STATUS_UNCATEGORIZED」。如果「EventType」為「AGENT_SHUTDOWN」,則「metadata.event_type」為「STATUS_SHUTDOWN」。如果「EventType」是「AGENT_STARTUP」或「BROKER_LMV_REMOTE_POD_DESKTOP_LAUNCH」,則「metadata.event_type」為「STATUS_STARTUP」。否則「metadata.event_type」為「GENERIC_EVENT」。
metadata.log_type 值設為「VMWARE_HORIZON」。
metadata.product_name 值設為「HORIZON」。
metadata.vendor_name 值設為「VMWARE」。

還有其他問題嗎?向社群成員和 Google SecOps 專業人員尋求答案。