Mengumpulkan log NGINX

Didukung di:

Dokumen ini menjelaskan cara menyerap log NGINX ke Google Security Operations menggunakan agen Bindplane.

NGINX adalah server web dan reverse proxy yang menghasilkan pesan syslog untuk peristiwa akses HTTP, peristiwa error, aktivitas autentikasi, dan informasi proses. Parser mengekstrak kolom dari beberapa format log (syslog, JSON, log akses) menggunakan pola grok dan memetakannya ke Model Data Terpadu (UDM).

Sebelum memulai

Pastikan Anda memiliki prasyarat berikut:

  • Instance Google SecOps
  • Windows Server 2016 atau yang lebih baru, atau host Linux dengan systemd
  • Konektivitas jaringan antara agen Bindplane dan server NGINX
  • Jika beroperasi dari balik proxy, pastikan port firewall terbuka sesuai dengan persyaratan agen Bindplane
  • Akses administratif ke host NGINX

Mendapatkan file autentikasi penyerapan Google SecOps

  1. Login ke konsol Google SecOps.
  2. Buka Setelan SIEM > Agen Pengumpulan.
  3. Download File Autentikasi Penyerapan.
  4. Simpan file dengan aman di sistem tempat agen BindPlane akan diinstal.

Mendapatkan ID pelanggan Google SecOps

  1. Login ke konsol Google SecOps.
  2. Buka Setelan SIEM > Profil.
  3. Salin dan simpan ID Pelanggan dari bagian Detail Organisasi.

Menginstal agen Bindplane

Instal agen Bindplane di sistem operasi Windows atau Linux Anda sesuai dengan petunjuk berikut.

Penginstalan Windows

  1. Buka Command Prompt atau PowerShell sebagai administrator.
  2. Jalankan perintah berikut:

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

  4. Verifikasi penginstalan dengan menjalankan:

    sc query observiq-otel-collector
    

    Layanan akan ditampilkan sebagai RUNNING.

Penginstalan Linux

  1. Buka terminal dengan hak istimewa root atau sudo.
  2. Jalankan perintah berikut:

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

  4. Verifikasi penginstalan dengan menjalankan:

    sudo systemctl status observiq-otel-collector
    

    Layanan akan ditampilkan sebagai aktif (berjalan).

Referensi penginstalan tambahan

Untuk opsi penginstalan dan pemecahan masalah tambahan, lihat Panduan penginstalan agen BindPlane.

Mengonfigurasi agen Bindplane untuk menyerap syslog dan mengirimkannya ke Google SecOps

Cari file konfigurasi

  • Linux:

    sudo nano /opt/observiq-otel-collector/config.yaml
    
  • Windows:

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

Edit file konfigurasi

  • Ganti seluruh konten config.yaml dengan konfigurasi berikut:

    receivers:
        udplog:
            listen_address: "0.0.0.0:514"
    
    exporters:
        chronicle/nginx:
            compression: gzip
            creds_file_path: '/etc/bindplane-agent/ingestion-auth.json'
            customer_id: '<customer_id>'
            endpoint: malachiteingestion-pa.googleapis.com
            log_type: NGINX
            raw_log_field: body
    
    service:
        pipelines:
            logs/nginx_to_chronicle:
                receivers:
                    - udplog
                exporters:
                    - chronicle/nginx
    

Parameter konfigurasi

Ganti placeholder berikut:

  • Konfigurasi penerima:

    • listen_address: Alamat IP dan port yang akan diproses:
      • 0.0.0.0 untuk mendengarkan di semua antarmuka (direkomendasikan)
      • Port 514 adalah port syslog standar (memerlukan root di Linux; gunakan 1514 untuk non-root)
  • Konfigurasi eksportir:

    • creds_file_path: Jalur lengkap ke file autentikasi penyerapan:
      • Linux: /etc/bindplane-agent/ingestion-auth.json
      • Windows: C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
    • customer_id: ID Pelanggan yang disalin dari konsol Google SecOps
    • endpoint: URL endpoint regional:
      • Amerika Serikat: malachiteingestion-pa.googleapis.com
      • Eropa: europe-malachiteingestion-pa.googleapis.com
      • Asia: asia-southeast1-malachiteingestion-pa.googleapis.com
      • Lihat Endpoint Regional untuk mengetahui daftar lengkapnya

Simpan file konfigurasi

  • Setelah mengedit, simpan file:
    • Linux: Tekan Ctrl+O, lalu Enter, lalu Ctrl+X
    • Windows: Klik File > Save

Mulai ulang agen Bindplane untuk menerapkan perubahan

  • Untuk memulai ulang agen Bindplane di Linux, jalankan perintah berikut:

    sudo systemctl restart observiq-otel-collector
    
    1. Pastikan layanan sedang berjalan:

      sudo systemctl status observiq-otel-collector
      
    2. Periksa log untuk mengetahui error:

      sudo journalctl -u observiq-otel-collector -f
      
  • Untuk memulai ulang agen Bindplane di Windows, pilih salah satu opsi berikut:

    • Command Prompt atau PowerShell sebagai administrator:

      net stop observiq-otel-collector && net start observiq-otel-collector
      
    • Konsol layanan:

      1. Tekan Win+R, ketik services.msc, lalu tekan Enter.
      2. Temukan observIQ OpenTelemetry Collector.
      3. Klik kanan, lalu pilih Mulai Ulang.
      4. Pastikan layanan sedang berjalan:

        sc query observiq-otel-collector
        
      5. Periksa log untuk mengetahui error:

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

Mengonfigurasi NGINX untuk meneruskan log ke BindPlane

  1. Buka file konfigurasi NGINX (misalnya, /etc/nginx/nginx.conf):

    sudo vi /etc/nginx/nginx.conf
    
  2. Edit konfigurasi, ganti <BINDPLANE_SERVER> dan <BINDPLANE_PORT> dengan nilai Anda:

    http {
        access_log syslog:server=<BINDPLANE_SERVER>:<BINDPLANE_PORT>,facility=local7,tag=nginx_access;
        error_log syslog:server=<BINDPLANE_SERVER>:<BINDPLANE_PORT>,facility=local7,tag=nginx_error;
    }
    
  3. Mulai ulang NGINX untuk menerapkan perubahan:

    sudo systemctl reload nginx
    

Tabel pemetaan UDM

Kolom Log Pemetaan UDM Logika
_Internal_WorkspaceResourceId target.resource.product_object_id Dipetakan secara langsung
Computer principal.asset.hostname Dipetakan secara langsung
Facility additional.fields[fasilitas] Dipetakan secara langsung
HostName principal.asset.hostname Dipetakan secara langsung jika src_ip tidak ada
ProcessName principal.application Dipetakan secara langsung
SeverityLevel security_result.severity Dipetakan ke INFORMATIONAL jika nilainya adalah info
SourceSystem principal.asset.platform Dipetakan ke LINUX jika nilainya cocok dengan Linux
SyslogMessage Beberapa kolom Diparsing menggunakan grok untuk mengekstrak time, method, target_path, protocol, response_code, referral_url, user_agent, target_ip, target_host, dan cache
TenantId additional.fields[TenantId] Dipetakan secara langsung
acct principal.user.user_id Dipetakan secara langsung jika tidak kosong atau ?
addr principal.asset.ip Dipetakan secara langsung
audit_epoch metadata.event_timestamp Dikonversi menjadi stempel waktu menggunakan format UNIX. Nanodetik diekstrak dari pesan log asli.
cache additional.fields[cache] Dipetakan secara langsung
collection_time.nanos metadata.event_timestamp.nanos Digunakan untuk nanodetik stempel waktu peristiwa jika tersedia
collection_time.seconds metadata.event_timestamp.seconds Digunakan untuk detik stempel waktu peristiwa jika tersedia
data Beberapa kolom Sumber data utama, diuraikan secara berbeda berdasarkan format log (Syslog, JSON, atau lainnya)
exe target.process.command_line Dipetakan secara langsung setelah menghapus garis miring terbalik dan tanda petik
hostname principal.asset.hostname ATAU principal.asset.ip Jika berupa alamat IP, dipetakan ke principal.asset.ip. Jika tidak, dipetakan ke principal.asset.hostname
msg metadata.description Dipetakan langsung sebagai deskripsi
node target.asset.hostname Dipetakan secara langsung
pid target.process.pid Dipetakan secara langsung
protocol network.application_protocol Dipetakan ke HTTP jika nilainya cocok dengan HTTP
referral_url network.http.referral_url Dipetakan secara langsung jika tidak kosong atau -
res security_result.action_details Dipetakan secara langsung
response_code network.http.response_code Dipetakan dan dikonversi langsung ke bilangan bulat
ses network.session_id Dipetakan secara langsung
src_ip principal.asset.ip Dipetakan secara langsung
target_host target.asset.hostname Dipetakan secara langsung
target_ip target.asset.ip Dipetakan secara langsung, setelah mengonversi representasi string ke array JSON, lalu mengekstrak setiap IP
target_path target.url Dipetakan secara langsung
time metadata.event_timestamp Diurai untuk mengekstrak stempel waktu menggunakan format dd/MMM/yyyy:HH:mm:ss Z
user_agent network.http.user_agent Dipetakan secara langsung jika tidak kosong atau -
metadata.event_type Disetel ke GENERIC_EVENT pada awalnya, lalu berpotensi diganti berdasarkan kolom lain seperti terminal dan protocol. Nilai defaultnya adalah USER_UNCATEGORIZED jika pola grok utama tidak cocok. Disetel ke NETWORK_HTTP jika protocol adalah HTTP dan target_ip ada, dan STATUS_UPDATE jika protocol adalah HTTP, tetapi target_ip tidak ada
metadata.log_type Disetel ke NGINX
metadata.product_name Disetel ke NGINX
metadata.vendor_name Disetel ke NGINX
network.ip_protocol Disetel ke TCP jika terminal adalah sshd atau ssh, atau jika pola grok utama tidak cocok
principal.asset_id Tetapkan ke GCP.GCE:0001 jika terminal adalah sshd atau ssh. Disetel ke GCP.GCE:0002 jika pola grok utama tidak cocok
extensions.auth.type Disetel ke MACHINE jika terminal adalah sshd atau ssh

Perlu bantuan lain? Dapatkan jawaban dari anggota Komunitas dan profesional Google SecOps.