Collecter les journaux MySQL

Compatible avec :

Ce document explique comment ingérer des journaux MySQL dans Google Security Operations à l'aide de l'agent Bindplane.

MySQL est un système de gestion de bases de données relationnelles qui génère des messages syslog pour les événements d'authentification, l'exécution de requêtes, les opérations de base de données et les entrées du journal d'audit. L'analyseur extrait les champs des journaux d'audit au format syslog et les mappe au modèle de données unifié (UDM).

Avant de commencer

Assurez-vous de remplir les conditions suivantes :

  • Une instance Google SecOps
  • Windows Server 2016 ou version ultérieure, ou hôte Linux avec systemd
  • Connectivité réseau entre l'agent Bindplane et le serveur MySQL
  • Si vous exécutez l'agent derrière un proxy, assurez-vous que les ports de pare-feu sont ouverts conformément aux exigences de l'agent Bindplane.
  • Accès SSH à l'hôte MySQL avec des droits root ou sudo

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.
  4. Enregistrez le fichier de manière sécurisée sur le système sur lequel l'agent 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
    
  3. Attendez la fin de l'installation.

  4. Vérifiez l'installation en exécutant la commande suivante :

    sc query observiq-otel-collector
    

    Le service doit être indiqué comme RUNNING (EN COURS D'EXÉCUTION).

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
    
  3. Attendez la fin de l'installation.

  4. Vérifiez l'installation en exécutant la commande suivante :

    sudo systemctl status observiq-otel-collector
    

    Le service doit être indiqué comme actif (en cours d'exécution).

Ressources d'installation supplémentaires

Pour obtenir d'autres options d'installation et des conseils de dépannage, consultez le guide d'installation de l'agent Bindplane.

Configurer l'agent Bindplane pour ingérer les journaux syslog et les envoyer à Google SecOps

Localiser le fichier de configuration

  • Linux :

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

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

Modifiez le fichier de configuration

  • Remplacez l'intégralité du contenu de config.yaml par la configuration suivante :

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

Paramètres de configuration

Remplacez les espaces réservés suivants :

  • Configuration du récepteur :

    • listen_address : adresse IP et port à écouter :
      • 0.0.0.0 pour écouter sur toutes les interfaces (recommandé)
      • Le port 514 est le port syslog standard (nécessite la racine sous Linux ; utilisez 1514 pour les utilisateurs non root).
  • Configuration de l'exportateur :

    • creds_file_path : chemin d'accès complet au fichier d'authentification de l'ingestion :
      • Linux : /etc/bindplane-agent/ingestion-auth.json
      • Windows : C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
    • customer_id : ID client copié depuis la console Google SecOps
    • endpoint : URL du point de terminaison régional :
      • États-Unis : malachiteingestion-pa.googleapis.com
      • Europe : europe-malachiteingestion-pa.googleapis.com
      • Asie : asia-southeast1-malachiteingestion-pa.googleapis.com
      • Pour obtenir la liste complète, consultez Points de terminaison régionaux.

Enregistrez le fichier de configuration.

  • Après avoir modifié le fichier, enregistrez-le :
    • Linux : appuyez sur Ctrl+O, puis sur Enter, puis sur Ctrl+X.
    • Windows : cliquez sur Fichier > Enregistrer.

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 observiq-otel-collector
    
    1. Vérifiez que le service est en cours d'exécution :

      sudo systemctl status observiq-otel-collector
      
    2. Recherchez les erreurs dans les journaux :

      sudo journalctl -u observiq-otel-collector -f
      
  • Pour redémarrer l'agent Bindplane dans Windows, choisissez l'une des options suivantes :

    • Invite de commande ou PowerShell en tant qu'administrateur :

      net stop observiq-otel-collector && net start observiq-otel-collector
      
    • Console Services :

      1. Appuyez sur Win+R, saisissez services.msc, puis appuyez sur Entrée.
      2. Localisez le collecteur observIQ OpenTelemetry.
      3. Effectuez un clic droit, puis sélectionnez Redémarrer.
      4. Vérifiez que le service est en cours d'exécution :

        sc query observiq-otel-collector
        
      5. Recherchez les erreurs dans les journaux :

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

Configurer syslog dans MySQL

  1. Connectez-vous à l'hôte MySQL à l'aide de SSH.
  2. Connectez-vous à la base de données MySQL :

    mysql -u root -p
    
  3. Vérifiez le plug-in d'audit server_audit.so :

    show variables like 'plugin_dir';
    
  4. Si le plug-in est introuvable, installez-le :

    install plugin server_audit soname 'server_audit.so';
    
  5. Vérifiez que le plug-in est installé et activé :

    show plugins;
    
  6. Modifiez le fichier /etc/my.cnf et activez les paramètres d'audit suivants :

    server_audit_events='CONNECT,QUERY,TABLE'
    server_audit_file_path=server_audit.log
    server_audit_logging=ON
    server_audit_output_type=SYSLOG
    server_audit_syslog_facility=LOG_LOCAL6
    
  7. Vérifiez les variables d'audit :

    show global variables like "server_audit%";
    
  8. Vérifiez que l'audit est activé :

    Show global status like 'server_audit%';
    
  9. Modifiez le fichier /etc/rsyslog.conf pour activer le transfert via UDP :

    *.* @@<bindplane-agent-ip>:<bindplane-agent-port>
    
    • Remplacez <bindplane-agent-ip> et <bindplane-agent-port> par la configuration de votre agent Bindplane.
  10. Redémarrez le service MySQL :

    /etc/init.d/mysqld restart
    

Table de mappage UDM

Champ du journal Mappage UDM Logique
action read_only_udm.metadata.event_type Si la valeur est Created, il s'agit de FILE_CREATION. Si la valeur est Deleted, il s'agit de FILE_DELETION. Sinon, aucun changement n'est effectué.
base de données read_only_udm.target.resource.parent
db_hostname read_only_udm.target.hostname
db_user read_only_udm.target.user.userid
description read_only_udm.security_result.description
error_details Il s'agit d'une variable temporaire. Ignorez-la.
error_level read_only_udm.security_result.severity Si la valeur est error, le niveau de gravité est défini sur "ERROR" (ERREUR). S'il est warning, il est défini sur "MEDIUM" (MOYEN). S'il est note, il est défini sur "INFORMATIONAL" (INFORMATIONNEL). Sinon, aucune modification n'est apportée.
error_message read_only_udm.security_result.summary
file_path read_only_udm.target.file.full_path
file_size read_only_udm.target.file.size
nom d'hôte read_only_udm.principal.hostname
inner_message read_only_udm.security_result.description
résumé read_only_udm.metadata.product_event_type
table read_only_udm.target.resource.name
table_not_found Il s'agit d'une variable temporaire. Ignorez-la.
timestamp read_only_udm.metadata.event_timestamp
read_only_udm.extensions.auth.type Valeur statique : MACHINE
read_only_udm.metadata.event_type Valeur statique : USER_LOGIN, GENERIC_EVENT, STATUS_UPDATE, FILE_CREATION, FILE_DELETION
read_only_udm.metadata.log_type Valeur statique : MYSQL
read_only_udm.metadata.product_name Valeur statique : MySQL
read_only_udm.metadata.vendor_name Valeur statique : Oracle Corporation
read_only_udm.security_result.action Valeur statique : BLOCK
read_only_udm.target.resource.resource_type Valeur statique : DATABASE, TABLE
properties.event_time event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
properties.ip event.idm.read_only_udm.principal.ip et event.idm.read_only_udm.principal.asset.ip Mappé à partir du journal des modifications
properties.user event.idm.read_only_udm.principal.user.userid Mappé à partir du journal des modifications
properties.error_code event.idm.read_only_udm.security_result.description Mappé à partir du journal des modifications
properties.event_subclass event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.is_aad_auth event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
category event.idm.read_only_udm.metadata.product_event_type Mappé à partir du journal des modifications
ServerType event.idm.read_only_udm.target.application Mappé à partir du journal des modifications
target_app event.idm.read_only_udm.target.application Mappé à partir du journal des modifications
properties.start_time event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
ts event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
time event.idm.read_only_udm.metadata.collected_timestamp Mappé à partir du journal des modifications
properties.server_id event.idm.read_only_udm.target.asset.asset_id Mappé à partir du journal des modifications
properties.thread_id event.idm.read_only_udm.principal.process.pid Mappé à partir du journal des modifications
user_id event.idm.read_only_udm.principal.user.userid Mappé à partir du journal des modifications
p_host event.idm.read_only_udm.principal.hostname Mappé à partir du journal des modifications
p_host event.idm.read_only_udm.principal.asset.hostname Mappé à partir du journal des modifications
properties.db event.idm.read_only_udm.target.resource.name Mappé à partir du journal des modifications
resourceId event.idm.read_only_udm.target.resource.product_object_id Mappé à partir du journal des modifications
operationName event.idm.read_only_udm.metadata.description Mappé à partir du journal des modifications
location event.idm.read_only_udm.target.location.name Mappé à partir du journal des modifications
properties.host event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.last_insert_id event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.insert_id event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.sql_text event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.rows_examined event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.rows_sent event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.lock_time event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.query_time event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.replication_set_role event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
properties.event_class event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
csv_principal_hostname event.idm.read_only_udm.principal.ip et event.idm.read_only_udm.principal.asset.ip Mappé à partir du journal des modifications
csv_hostname event.idm.read_only_udm.target.hostname et event.idm.read_only_udm.target.asset.hostname Mappé à partir du journal des modifications
csv_principal_hostname event.idm.read_only_udm.principal.hostname et event.idm.read_only_udm.principal.asset.hostname Mappé à partir du journal des modifications
ts event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
csv_query_id event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
csv_mysql event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
account_host event.idm.read_only_udm.principal.resource.attribute.labels Mappé à partir du journal des modifications
login_proxy event.idm.read_only_udm.principal.resource.attribute.labels Mappé à partir du journal des modifications
login_os event.idm.read_only_udm.principal.resource.attribute.labels Mappé à partir du journal des modifications
arg event.idm.read_only_udm.principal.resource.attribute.labels Mappé à partir du journal des modifications
startup_data_server_id event.idm.read_only_udm.principal.resource.product_object_id Mappé à partir du journal des modifications
startup_data_os_version event.idm.read_only_udm.principal.platform_version Mappé à partir du journal des modifications
startup_data_mysql_version event.idm.read_only_udm.metadata.product_version Mappé à partir du journal des modifications
arg event.idm.read_only_udm.principal.process.command_line Mappé à partir du journal des modifications
csv_mysql_sql_query event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
hostname event.idm.read_only_udm.intermediary.hostname et event.idm.read_only_udm.intermediary.asset.hostname Mappé à partir du journal des modifications
id event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
login.proxy event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
connection_data.connection_type event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
connection_data.status event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
login.os event.idm.read_only_udm.principal.platform_version Mappé à partir du journal des modifications
account.host event.idm.read_only_udm.target.hostname et event.idm.read_only_udm.target.asset.hostname Mappé à partir du journal des modifications
connection_data.db event.idm.read_only_udm.target.application Mappé à partir du journal des modifications
mysql_description event.idm.read_only_udm.metadata.description Mappé à partir du journal des modifications
mysql_errno event.idm.read_only_udm.metadata.product_log_id Mappé à partir du journal des modifications
mysql_version event.idm.read_only_udm.metadata.product_version Mappé à partir du journal des modifications
process_path event.idm.read_only_udm.principal.process.file.full_path Mappé à partir du journal des modifications
mysql_port event.idm.read_only_udm.principal.port Mappé à partir du journal des modifications
status event.idm.read_only_udm.security_result.summary Mappé à partir du journal des modifications
error_level event.idm.read_only_udm.security_result.severity_details Mappé à partir du journal des modifications
mysql_thread_id event.idm.read_only_udm.network.session_id Mappé à partir du journal des modifications
mysql_socket event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
log_level event.idm.read_only_udm.additional.fields Mappé à partir du journal des modifications
mysql_timestamp event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
event_date event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
event_time event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
csv_timestamp event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
mysql_action event.idm.read_only_udm.metadata.product_event_type Mappé à partir du journal des modifications
log_category event.idm.read_only_udm.metadata.product_event_type Mappé à partir du journal des modifications
csv_mysql_action event.idm.read_only_udm.metadata.product_event_type Mappé à partir du journal des modifications
csv_mysql_connection_type event.idm.read_only_udm.metadata.product_event_type Mappé à partir du journal des modifications
event_message event.idm.read_only_udm.metadata.description Mappé à partir du journal des modifications
resolution_error event.idm.read_only_udm.metadata.description Mappé à partir du journal des modifications
component event.idm.read_only_udm.principal.application Mappé à partir du journal des modifications
mysql_hostname event.idm.read_only_udm.principal.ip et event.idm.read_only_udm.principal.asset.ip Mappé à partir du journal des modifications
csv_hostname_ip event.idm.read_only_udm.principal.ip et event.idm.read_only_udm.principal.asset.ip Mappé à partir du journal des modifications
mysql_username event.idm.read_only_udm.principal.user.userid Mappé à partir du journal des modifications
csv_username event.idm.read_only_udm.principal.user.userid Mappé à partir du journal des modifications
csv_target_hostname event.idm.read_only_udm.target.hostname et event.idm.read_only_udm.target.asset.hostname Mappé à partir du journal des modifications
csv_database_name event.idm.read_only_udm.target.resource.name Mappé à partir du journal des modifications
mysql_sql_query event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
csv_connection_id event.idm.read_only_udm.network.session_id Mappé à partir du journal des modifications
mysql_message_id event.idm.read_only_udm.security_result.rule_id Mappé à partir du journal des modifications
target_mysql_hostname event.idm.read_only_udm.target.hostname et event.idm.read_only_udm.target.asset.hostname Mappé à partir du journal des modifications
csv_mysql_connection_type event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
login.ip event.idm.read_only_udm.principal.ip Mappé à partir du journal des modifications
login.ip event.idm.read_only_udm.principal.asset.ip Mappé à partir du journal des modifications
login.user event.idm.read_only_udm.principal.user.userid Mappé à partir du journal des modifications
account.user event.idm.read_only_udm.target.user.userid Mappé à partir du journal des modifications
inter_host event.idm.read_only_udm.intermediary.hostname Mappé à partir du journal des modifications
target_host event.idm.read_only_udm.target.hostname Mappé à partir du journal des modifications
target_host event.idm.read_only_udm.target.asset.hostname Mappé à partir du journal des modifications
target_ip event.idm.read_only_udm.target.ip Mappé à partir du journal des modifications
target_ip event.idm.read_only_udm.target.asset.ip Mappé à partir du journal des modifications
connection_id event.idm.read_only_udm.network.session_id Mappé à partir du journal des modifications
general_data.command event.idm.read_only_udm.target.process.command_line Mappé à partir du journal des modifications
general_data.query event.idm.read_only_udm.security_result.summary Mappé à partir du journal des modifications
connection_data.connection_type event.idm.read_only_udm.network.ip_protocol Mappé à partir du journal des modifications
general_data.sql_command event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
event_data event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
general_data.status event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
class event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
Status event.idm.read_only_udm.security_result.detection_fields Mappé à partir du journal des modifications
sql_query event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
value event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
num event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
ns event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
itemid event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
value_min event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
value_avg event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
value_max event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
query_id event.idm.read_only_udm.target.resource.attribute.labels Mappé à partir du journal des modifications
clock event.idm.read_only_udm.metadata.event_timestamp Mappé à partir du journal des modifications
path principal.file.full_path Mappé à partir du journal des modifications
logtype metadata.product_event_type Mappé à partir du journal des modifications

Journal des modifications

Afficher le journal des modifications pour ce parseur

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