Collecter les journaux VMware Tanzu

Compatible avec :

Ce document explique comment ingérer des journaux VMware Tanzu dans Google Security Operations à l'aide de Bindplane. L'analyseur extrait les journaux d'audit des messages au format JSON ou SYSLOG+JSON. Il analyse les données de journaux, normalise les champs au format UDM et enrichit l'événement avec des métadonnées telles que les informations sur l'utilisateur, les informations sur les ressources, l'activité réseau et les résultats de sécurité. Il gère à la fois les objets JSON uniques et les objets JSON intégrés dans les messages syslog.

Avant de commencer

Assurez-vous de remplir les conditions suivantes :

  • Instance Google SecOps
  • Windows 2016 ou version ultérieure, ou un hôte Linux avec systemd
  • Si vous exécutez le programme derrière un proxy, assurez-vous que les ports du pare-feu sont ouverts.
  • Accès privilégié à VMware Tanzu

Obtenir le fichier d'authentification d'ingestion Google SecOps

  1. Connectez-vous à la console Google SecOps.
  2. Accédez à Paramètres du SIEM > Agents de collecte.
  3. Téléchargez le fichier d'authentification d'ingestion. Enregistrez le fichier de manière sécurisée sur le système sur lequel Bindplane sera installé.

Obtenir l'ID client Google SecOps

  1. Connectez-vous à la console Google SecOps.
  2. Accédez à Paramètres SIEM> Profil.
  3. Copiez et enregistrez le numéro client de la section Informations sur l'organisation.

Installer l'agent Bindplane

Installez l'agent Bindplane sur votre système d'exploitation Windows ou Linux en suivant les instructions ci-dessous.

Installation de fenêtres

  1. Ouvrez l'invite de commandes ou PowerShell en tant qu'administrateur.
  2. Exécutez la commande suivante :

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

Installation de Linux

  1. Ouvrez un terminal avec les droits root ou sudo.
  2. Exécutez la commande suivante :

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

Ressources d'installation supplémentaires

Pour plus d'options d'installation, consultez le guide d'installation.

Configurer l'agent Bindplane pour ingérer Syslog et l'envoyer à Google SecOps

  1. Accédez au fichier de configuration :
    • Trouvez le fichier config.yaml. En règle générale, il se trouve dans le répertoire /etc/bindplane-agent/ sous Linux ou dans le répertoire d'installation sous Windows.
    • Ouvrez le fichier à l'aide d'un éditeur de texte (par exemple, nano, vi ou le Bloc-notes).
  2. Modifiez le fichier config.yaml comme suit :

    receivers:
        udplog:
            # Replace the port and IP address as required
            listen_address: "0.0.0.0:514"
    
    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
            log_type: 'VMWARE_TANZU'
            raw_log_field: body
            ingestion_labels:
    
    service:
        pipelines:
            logs/source0__chronicle_w_labels-0:
                receivers:
                    - udplog
                exporters:
                    - chronicle/chronicle_w_labels
    
    • Remplacez le port et l'adresse IP selon les besoins de votre infrastructure.
    • Remplacez <customer_id> par le numéro client réel.
    • Mettez à jour /path/to/ingestion-authentication-file.json en indiquant le chemin d'accès où le fichier d'authentification a été enregistré dans la section Obtenir le fichier d'authentification pour l'ingestion Google SecOps.

Redémarrez l'agent Bindplane pour appliquer les modifications.

  • Pour redémarrer l'agent Bindplane sous Linux, exécutez la commande suivante :

    sudo systemctl restart bindplane-agent
    
  • Pour redémarrer l'agent Bindplane sous Windows, vous pouvez utiliser la console Services ou saisir la commande suivante :

    net stop BindPlaneAgent && net start BindPlaneAgent
    

Configurer Syslog pour VMware Tanzu

  1. Connectez-vous à l'interface utilisateur Web Tanzu Operations Manager.
  2. Sélectionnez votre nom d'utilisateur, puis cliquez sur Paramètres.
  3. Sélectionnez Syslog.
  4. Cliquez sur Oui pour envoyer les journaux système à un serveur distant.
  5. Fournissez les informations de configuration suivantes :
    • Adresse : saisissez l'adresse IP de l'agent Bindplane.
    • Port : saisissez le numéro de port de l'agent Bindplane.
    • Protocole de transport : sélectionnez UDP ou TCP, en fonction de la configuration réelle de votre agent Bindplane.
  6. Cliquez sur Enregistrer.

Table de mappage UDM

Champ de journal Mappage UDM Logique
annotations.authorization.k8s.io/decision security_result.action Si l'annotation authorization.k8s.io/decision existe, sa valeur est convertie en majuscules. Si la valeur en majuscules est "ALLOW", le champ UDM est défini sur ALLOW. Sinon, la valeur est définie sur BLOCK.
annotations.authorization.k8s.io/reason security_result.description Si l'annotation authorization.k8s.io/reason existe, sa valeur (sans les guillemets doubles) est utilisée.
apiVersion metadata.product_version Mappé directement.
auditID metadata.product_log_id Mappé directement.
kind metadata.product_event_type Mappé directement.
objectRef.name target.resource.name Mappé directement.
objectRef.namespace target.resource.attribute.labels.key, target.resource.attribute.labels.value key est défini sur "namespace" et value est extrait de objectRef.namespace.
objectRef.resource target.resource.resource_subtype Mappé directement.
objectRef.resourceVersion target.resource.attribute.labels.key, target.resource.attribute.labels.value key est défini sur "resourceVersion" et value est extrait de objectRef.resourceVersion.
objectRef.uid target.resource.product_object_id Mappé directement.
requestReceivedTimestamp/timestamp metadata.event_timestamp L'analyseur tente d'abord d'analyser requestReceivedTimestamp. Si elle n'est pas présente, le champ timestamp extrait du préfixe syslog est utilisé.
requestURI target.url Mappé directement.
responseStatus.code network.http.response_code Mappé directement après avoir été converti en entier.
sourceIPs principal.ip Toutes les adresses IP du tableau sourceIPs sont ajoutées au tableau principal.ip.
stage metadata.description Mappé directement.
stageTimestamp metadata.collected_timestamp Mappé directement.
user.groups principal.user.group_identifiers Tous les groupes du tableau user.groups sont ajoutés au tableau principal.user.group_identifiers.
user.uid principal.user.userid Mappé directement.
user.username principal.user.user_display_name Mappé directement.
verb network.http.method Mappé directement après avoir été converti en majuscules. Déterminé par le champ verb. Si verb est défini sur "CREATE", le type d'événement est USER_RESOURCE_CREATION. Si verb est défini sur "PATCH" ou "UPDATE", le type d'événement est USER_RESOURCE_UPDATE_CONTENT. Si verb est défini sur "DELETE", le type d'événement est USER_RESOURCE_DELETION. Sinon, si verb n'est pas vide, le type d'événement est USER_RESOURCE_ACCESS. Si aucune de ces conditions n'est remplie, le type d'événement est défini sur GENERIC_EVENT. Codé en dur sur "VMWARE_TANZU". Codé en dur sur "VMWARE". Codé en dur sur "VMWARE_TANZU". Codé en dur sur "CLUSTER".

Vous avez encore besoin d'aide ? Obtenez des réponses de membres de la communauté et de professionnels Google SecOps.