收集 FileZilla FTP 記錄檔

支援以下發布途徑:

本文說明如何使用 Bindplane,將 FileZilla 記錄匯入 Google Security Operations。Logstash 剖析器程式碼會從 FileZilla FTP 伺服器記錄中擷取相關欄位,例如時間戳記、主機名稱、使用者 ID 和說明。接著,將這些擷取的欄位結構化為統合式資料模型 (UDM),以便進行一致的安全性分析和關聯。

事前準備

請確認您已具備下列必要條件:

  • Google SecOps 執行個體
  • Windows 2016 以上版本,或搭載 systemd 的 Linux 主機
  • 如果在 Proxy 後方執行,防火牆通訊埠會開啟
  • 對 FileZilla Server 執行個體的特殊存取權

取得 Google SecOps 擷取驗證檔案

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

取得 Google SecOps 客戶 ID

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

在 FileZilla Server 執行個體上安裝 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. 開啟具有 root 或 sudo 權限的終端機。
  2. 執行下列指令:

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

其他安裝資源

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

設定 Bindplane 代理程式,以便擷取 syslog 並傳送至 Google SecOps

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

    receivers:
        filelog:
            # Adjust the path to the log file
            file_path: <PATH_TO>/filezilla-logs.log
            log_type: 'file'
    
    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
            ingestion_labels:
                log_type: 'FILEZILLA_FTP'
                raw_log_field: body
    
    service:
        pipelines:
            logs/source0__chronicle_w_labels-0:
                receivers:
                  - filelog
                exporters:
                    - chronicle/chronicle_w_labels
    
    • 視基礎架構需求替換通訊埠和 IP 位址。
    • <customer_id> 替換為實際的客戶 ID。
    • 在「取得 Google SecOps 攝入驗證檔案」部分,將 /path/to/ingestion-authentication-file.json 更新為驗證檔案的儲存路徑。

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

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

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

    net stop BindPlaneAgent && net start BindPlaneAgent
    

在 FileZilla 中設定記錄功能

  1. 使用 FileZilla 登入伺服器。
  2. 開啟 FileZilla 軟體。
  3. 依序前往「編輯」>「設定」
  4. 在選單中選取「記錄」
  5. 提供下列設定詳細資料:
    • 勾選「Show timestamps in messagebox」(在訊息方塊中顯示時間戳記) 核取方塊。
    • 勾選「記錄至檔案」核取方塊。
    • 檔案名稱:輸入檔案名稱,然後選取儲存路徑 (例如 filezilla-logs)。
    • 選用:限制記錄檔大小:勾選這個核取方塊,即可限制記錄檔可使用的空間量。
    • 選用:限制:您可以在這裡輸入記錄檔的大小上限 (以 MB 為單位)。
  6. 按一下 [確定]
  7. 重新啟動 FileZilla。

UDM 對應表

記錄欄位 UDM 對應 邏輯
資料 read_only_udm.metadata.description 原始記錄 data 欄位內容。
資料 read_only_udm.metadata.event_timestamp.seconds 使用 grok 模式從 data 欄位擷取,並轉換為 Epoch 秒。
資料 read_only_udm.network.http.response_code 使用 grok 模式從 data 欄位擷取。
資料 read_only_udm.principal.hostname 使用 grok 模式從 data 欄位擷取。
資料 read_only_udm.principal.port 使用 grok 模式從 data 欄位擷取。
資料 read_only_udm.principal.user.userid 使用 grok 模式從 data 欄位擷取,但只有在值不是 not logged in 時才會擷取。
資料 read_only_udm.target.ip 使用 grok 模式從 data 欄位擷取。
資料 read_only_udm.target.process.pid 使用 grok 模式從 data 欄位擷取。
read_only_udm.metadata.event_type 如果 target.ip 存在,請設為 NETWORK_FTP,否則設為 GENERIC_EVENT
read_only_udm.metadata.log_type 設為 FILEZILLA_FTP
read_only_udm.metadata.product_name 設為 FILEZILLA
read_only_udm.metadata.vendor_name 設為 FILEZILLA

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