Mengumpulkan log VMware Tanzu

Didukung di:

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

VMware Tanzu adalah platform Kubernetes yang menghasilkan log audit berformat JSON dan syslog untuk peristiwa server Kubernetes API, akses resource, keputusan autentikasi, dan perubahan konfigurasi. Parser mengekstrak kolom dari log audit berformat JSON 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 Tanzu Operations Manager
  • Jika beroperasi dari balik proxy, pastikan port firewall terbuka sesuai dengan persyaratan agen Bindplane
  • Akses istimewa ke VMware Tanzu

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 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/vmware_tanzu:
            compression: gzip
            creds_file_path: '/etc/bindplane-agent/ingestion-auth.json'
            customer_id: '<customer_id>'
            endpoint: malachiteingestion-pa.googleapis.com
            log_type: VMWARE_TANZU
            raw_log_field: body
    
    service:
        pipelines:
            logs/vmware_tanzu_to_chronicle:
                receivers:
                    - udplog
                exporters:
                    - chronicle/vmware_tanzu
    

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 syslog untuk VMware Tanzu

  1. Login ke UI web Tanzu Operations Manager.
  2. Pilih Nama pengguna Anda, lalu klik Setelan.
  3. Pilih Syslog.
  4. Klik Ya untuk mengirim log sistem ke server jarak jauh.
  5. Berikan detail konfigurasi berikut:
    • Alamat: Masukkan alamat IP agen Bindplane.
    • Port: Masukkan nomor port agen Bindplane.
    • Transport Protocol: Pilih UDP atau TCP, bergantung pada konfigurasi agen Bindplane Anda.
  6. Klik Simpan.

Tabel pemetaan UDM

Kolom Log Pemetaan UDM Logika
annotations.authorization.k8s.io/decision security_result.action Jika anotasi authorization.k8s.io/decision ada, nilainya akan dikonversi menjadi huruf besar. Jika nilai huruf besar adalah "ALLOW", kolom UDM akan ditetapkan ke ALLOW. Jika tidak, nilai ini akan ditetapkan ke BLOCK.
annotations.authorization.k8s.io/reason security_result.description Jika anotasi authorization.k8s.io/reason ada, nilainya (dengan tanda kutip ganda dihapus) akan digunakan.
apiVersion metadata.product_version Dipetakan secara langsung.
auditID metadata.product_log_id Dipetakan secara langsung.
kind metadata.product_event_type Dipetakan secara langsung.
objectRef.name target.resource.name Dipetakan secara langsung.
objectRef.namespace target.resource.attribute.labels.key, target.resource.attribute.labels.value key disetel ke "namespace", dan value diambil dari objectRef.namespace.
objectRef.resource target.resource.resource_subtype Dipetakan secara langsung.
objectRef.resourceVersion target.resource.attribute.labels.key, target.resource.attribute.labels.value key disetel ke "resourceVersion", dan value diambil dari objectRef.resourceVersion.
objectRef.uid target.resource.product_object_id Dipetakan secara langsung.
requestReceivedTimestamp/timestamp metadata.event_timestamp Parser mencoba mengurai requestReceivedTimestamp terlebih dahulu. Jika tidak ada, kolom ini akan menggunakan kolom timestamp yang diekstrak dari awalan syslog.
requestURI target.url Dipetakan secara langsung.
responseStatus.code network.http.response_code Dipetakan secara langsung setelah dikonversi menjadi bilangan bulat.
sourceIPs principal.ip Semua alamat IP dalam array sourceIPs ditambahkan ke array principal.ip.
stage metadata.description Dipetakan secara langsung.
stageTimestamp metadata.collected_timestamp Dipetakan secara langsung.
user.groups principal.user.group_identifiers Semua grup dalam array user.groups ditambahkan ke array principal.user.group_identifiers.
user.uid principal.user.userid Dipetakan secara langsung.
user.username principal.user.user_display_name Dipetakan secara langsung.
verb network.http.method Dipetakan secara langsung setelah dikonversi menjadi huruf besar. Ditentukan oleh kolom verb. Jika verb adalah "CREATE", jenis peristiwanya adalah USER_RESOURCE_CREATION. Jika verb adalah "PATCH" atau "UPDATE", jenis peristiwanya adalah USER_RESOURCE_UPDATE_CONTENT. Jika verb adalah "DELETE", jenis peristiwanya adalah USER_RESOURCE_DELETION. Jika tidak, jika verb tidak kosong, jenis peristiwanya adalah USER_RESOURCE_ACCESS. Jika tidak satu pun dari kondisi ini terpenuhi, jenis peristiwa akan ditetapkan ke GENERIC_EVENT. Dikodekan secara permanen ke "VMWARE_TANZU". Dikodekan secara permanen ke "VMWARE". Dikodekan secara permanen ke "VMWARE_TANZU". Dikodekan secara permanen ke "CLUSTER".

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