收集 Big Switch BigCloudFabric 記錄

支援的國家/地區:

本文說明如何使用 Bindplane 代理程式,將 Big Switch BigCloudFabric 記錄檔擷取至 Google Security Operations。

Arista Networks Big Cloud Fabric (BCF,現稱 Converged Cloud Fabric (CCF)) 是一種軟體定義的網路 (SDN) 解決方案,可透過集中式控制器提供自動化資料中心架構管理。BCF/CCF 控制器可管理 Leaf-Spine 網路架構,為企業資料中心網路提供集中式設定、監控和疑難排解功能。這項產品最初由 Big Switch Networks 開發,後來由 Arista Networks 收購。

事前準備

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

  • Google SecOps 執行個體
  • Windows Server 2016 以上版本,或搭載 systemd 的 Linux 主機
  • Bindplane 代理程式與 BCF/CCF 控制器之間的網路連線
  • 如果透過 Proxy 執行,請確保防火牆通訊埠已根據 Bindplane 代理程式需求開啟
  • 透過 GUI 或 CLI 管理 BCF/CCF 控制器的存取權
  • BCF/CCF 控制器 2.5 以上版本 (支援系統記錄)

取得 Google SecOps 擷取驗證檔案

  1. 登入 Google SecOps 控制台。
  2. 依序前往「SIEM 設定」>「收集代理程式」
  3. 下載擷取驗證檔案
  4. 將檔案安全地儲存在要安裝 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
    
  3. 等待安裝完成。

  4. 執行下列指令來驗證安裝:

    sc query observiq-otel-collector
    

    服務應顯示為「RUNNING」(執行中)

Linux 安裝

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

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. 等待安裝完成。

  4. 執行下列指令來驗證安裝:

    sudo systemctl status observiq-otel-collector
    

    服務應顯示為啟用 (執行中)

其他安裝資源

如需其他安裝選項和疑難排解資訊,請參閱 Bindplane 代理程式安裝指南

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

找出設定檔

  • Linux:

    sudo nano /etc/bindplane-agent/config.yaml
    
  • Windows:

    notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
    

編輯設定檔

  1. config.yaml 的所有內容替換為下列設定:

    receivers:
        udplog:
            listen_address: "0.0.0.0:514"
    
    exporters:
        chronicle/bigswitch_bcf:
            compression: gzip
            creds_file_path: '/etc/bindplane-agent/ingestion-auth.json'
            customer_id: 'YOUR_CUSTOMER_ID'
            endpoint: malachiteingestion-pa.googleapis.com
            log_type: BIGSWITCH_BCF
            raw_log_field: body
            ingestion_labels:
                env: production
                source: bcf_controller
    
    service:
        pipelines:
            logs/bcf_to_chronicle:
                receivers:
                    - udplog
                exporters:
                    - chronicle/bigswitch_bcf
    
  2. 替換下列預留位置:

    • 接收器設定:

      • 接收器已設定為監聽 UDP 通訊埠 514,接收來自 BCF/CCF 控制器的系統記錄檔訊息
      • 如要使用其他通訊埠,請將 514 變更為所需的通訊埠號碼 (例如,針對無權限的 Linux 安裝作業,請使用 1514)
    • 匯出工具設定:

      • creds_file_path:擷取驗證檔案的完整路徑:

        • Linux/etc/bindplane-agent/ingestion-auth.json
        • WindowsC:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
      • YOUR_CUSTOMER_ID:請替換為您的 Customer ID。詳情請參閱「取得 Google SecOps 客戶 ID」。

      • endpoint:區域端點網址:

        • 美國malachiteingestion-pa.googleapis.com
        • 歐洲europe-malachiteingestion-pa.googleapis.com
        • 亞洲asia-southeast1-malachiteingestion-pa.googleapis.com
        • 如需完整清單,請參閱「區域端點
      • log_type:設為 BIGSWITCH_BCF (請勿變更)

      • ingestion_labels:用於分類記錄的選用標籤 (可視需要自訂)

儲存設定檔

編輯完成後,請儲存檔案:

  • Linux:依序按下 Ctrl+OEnterCtrl+X
  • Windows:依序點選「檔案」>「儲存」

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

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

    1. 執行下列指令:

      sudo systemctl restart observiq-otel-collector
      
    2. 確認服務正在執行:

      sudo systemctl status observiq-otel-collector
      
    3. 檢查記錄中是否有錯誤:

      sudo journalctl -u observiq-otel-collector -f
      
  • 如要在 Windows 中重新啟動 Bindplane 代理程式,請按照下列步驟操作:

    1. 您可以選擇下列其中一個選項:

      • 以管理員身分開啟命令提示字元或 PowerShell:

        net stop observiq-otel-collector && net start observiq-otel-collector
        
      • 服務控制台:

        1. 按下 Win+R 鍵,輸入 services.msc,然後按下 Enter 鍵。
        2. 找出 observIQ OpenTelemetry Collector
        3. 按一下滑鼠右鍵,然後選取「重新啟動」
    2. 確認服務正在執行:

      sc query observiq-otel-collector
      
    3. 檢查記錄中是否有錯誤:

      type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
      

設定 Big Switch BigCloudFabric 系統記錄轉送

使用 GUI 或 CLI 方法,設定 BCF/CCF 控制器將系統記錄訊息轉送至 Bindplane 代理程式。

方法 1:使用 GUI 設定系統記錄

  1. 使用管理員憑證登入 BCF/CCF 控制器網頁介面。
  2. 依序前往「維護」>「記錄」
  3. 按一下「遠端記錄」分頁標籤。
  4. 按一下「新增」,建立新的遠端系統記錄檔伺服器設定。
  5. 請提供下列設定詳細資料:
    • 伺服器:輸入 Bindplane 代理程式主機的 IP 位址 (例如 192.168.1.100)。
    • 連接埠:輸入 514 (或 Bindplane 代理程式 config.yaml 中設定的連接埠)。
    • 「通訊協定」:選取「UDP」
  6. 按一下「儲存」或「套用」,儲存設定。
  7. 確認設定是否顯示在「遠端記錄」清單中。

方法 2:使用 CLI 設定系統記錄

  1. 使用管理員憑證,透過 SSH 連線至 BCF/CCF 控制器。
  2. 進入啟用模式:

    controller-1> enable
    
  3. 進入設定模式:

    controller-1# configure
    
  4. 設定遠端系統記錄檔伺服器:

    controller-1(config)# logging remote 192.168.1.100
    

    192.168.1.100 替換為 Bindplane 代理程式主機的 IP 位址。

  5. 退出設定模式:

    controller-1(config)# exit
    
  6. 驗證系統記錄設定:

    controller-1# show logging
    

    輸出內容應會顯示已設定的遠端系統記錄伺服器 IP 位址。

確認記錄轉送

  1. 在 BCF/CCF 控制器上進行設定變更或查看系統狀態,產生測試記錄事件。
  2. 查看 Bindplane 代理程式記錄,確認是否收到 Syslog 訊息:

    • Linux:

      sudo journalctl -u observiq-otel-collector -f
      
    • Windows:

      type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
      
  3. 登入 Google SecOps 控制台,確認記錄是否顯示在「搜尋」介面中,並附上擷取標籤 BIGSWITCH_BCF

UDM 對應表

記錄欄位 UDM 對應 邏輯
說明 metadata.description 直接複製值,並移除開頭和結尾的空格
target_host、time、product_event_type、description、application metadata.event_type 如果 target_host 和時間不為空白,則設為 STATUS_HEARTBEAT;如果 product_event_type == PORT_DOWN,則設為 SERVICE_STOP;如果說明符合「.Running job.」或 product_event_type == PORT_UP 或 application == snmpd-execstart,則設為 SERVICE_START;如果說明符合「.status down.」,則設為 STATUS_SHUTDOWN;如果 product_event_type == Removing Endpoint,則為 SERVICE_DELETION;如果 product_event_type == Adding Endpoint,則為 SERVICE_CREATION;如果 product_event_type == Moving Endpoint 或說明符合「.change instances.」,則為 SERVICE_MODIFICATION;如果 target_host 不為空白,則為 NETWORK_CONNECTION;否則為 GENERIC_EVENT
product_event_type metadata.product_event_type 直接複製值
application_protocol network.application_protocol 如果 application_protocol ==「lldpa」,則設為「UNKNOWN_APPLICATION_PROTOCOL」
主機 principal.hostname 直接複製值
ip principal.ip 直接複製值
process_id principal.process.pid 直接複製值
使用者 principal.user.userid 直接複製值
log_level security_result 如果嚴重程度為「INFO」或「WARN」,物件的嚴重程度會設為「INFORMATIONAL」,動作會設為「ALLOW」;如果嚴重程度為「ERROR」,物件的嚴重程度會設為「HIGH」,動作會設為「BLOCK」
調度應用程式資源 target.application 直接複製值
target_host target.hostname 直接複製值
通訊埠 target.port 已轉換為整數
COMMAND target.process.command_line 直接複製值
product_specific_id target.process.product_specific_process_id 開頭為「Bigswitch:」
kv_1、kv2、kv3 target.user.group_identifiers 如果 kv_1、kv2、kv3 不為空白,則從這些值合併
metadata.product_name 設為「Big Cloud Fabric」
metadata.vendor_name 設為「Big Switch」

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