Mengumpulkan log NGINX
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
- Login ke konsol Google SecOps.
- Buka Setelan SIEM > Agen Pengumpulan.
- Download File Autentikasi Penyerapan.
Simpan file dengan aman di sistem tempat agen BindPlane akan diinstal.
Mendapatkan ID pelanggan Google SecOps
- Login ke konsol Google SecOps.
- Buka Setelan SIEM > Profil.
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
- Buka Command Prompt atau PowerShell sebagai administrator.
Jalankan perintah berikut:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietTunggu hingga penginstalan selesai.
Verifikasi penginstalan dengan menjalankan:
sc query observiq-otel-collectorLayanan akan ditampilkan sebagai RUNNING.
Penginstalan Linux
- Buka terminal dengan hak istimewa root atau sudo.
Jalankan perintah berikut:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shTunggu hingga penginstalan selesai.
Verifikasi penginstalan dengan menjalankan:
sudo systemctl status observiq-otel-collectorLayanan 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.yamlWindows:
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Edit file konfigurasi
Ganti seluruh konten
config.yamldengan 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.0untuk mendengarkan di semua antarmuka (direkomendasikan)- Port
514adalah port syslog standar (memerlukan root di Linux; gunakan1514untuk 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
- Linux:
customer_id: ID Pelanggan yang disalin dari konsol Google SecOpsendpoint: 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
- Amerika Serikat:
Simpan file konfigurasi
- Setelah mengedit, simpan file:
- Linux: Tekan
Ctrl+O, laluEnter, laluCtrl+X - Windows: Klik File > Save
- Linux: Tekan
Mulai ulang agen Bindplane untuk menerapkan perubahan
Untuk memulai ulang agen Bindplane di Linux, jalankan perintah berikut:
sudo systemctl restart observiq-otel-collectorPastikan layanan sedang berjalan:
sudo systemctl status observiq-otel-collectorPeriksa 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-collectorKonsol layanan:
- Tekan
Win+R, ketikservices.msc, lalu tekan Enter. - Temukan observIQ OpenTelemetry Collector.
- Klik kanan, lalu pilih Mulai Ulang.
Pastikan layanan sedang berjalan:
sc query observiq-otel-collectorPeriksa log untuk mengetahui error:
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Tekan
Mengonfigurasi NGINX untuk meneruskan log ke BindPlane
Buka file konfigurasi NGINX (misalnya,
/etc/nginx/nginx.conf):sudo vi /etc/nginx/nginx.confEdit 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; }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.