Collecter les journaux MySQL
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
- Connectez-vous à la console Google SecOps.
- Accédez à Paramètres du SIEM > Agents de collecte.
- Téléchargez le fichier d'authentification d'ingestion.
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
- Connectez-vous à la console Google SecOps.
- Accédez à Paramètres SIEM> Profil.
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
- Ouvrez l'invite de commandes ou PowerShell en tant qu'administrateur.
Exécutez la commande suivante :
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietAttendez la fin de l'installation.
Vérifiez l'installation en exécutant la commande suivante :
sc query observiq-otel-collectorLe service doit être indiqué comme RUNNING (EN COURS D'EXÉCUTION).
Installation de Linux
- Ouvrez un terminal avec les droits root ou sudo.
Exécutez la commande suivante :
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shAttendez la fin de l'installation.
Vérifiez l'installation en exécutant la commande suivante :
sudo systemctl status observiq-otel-collectorLe 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.yamlWindows :
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Modifiez le fichier de configuration
Remplacez l'intégralité du contenu de
config.yamlpar 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.0pour écouter sur toutes les interfaces (recommandé)- Le port
514est le port syslog standard (nécessite la racine sous Linux ; utilisez1514pour 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
- Linux :
customer_id: ID client copié depuis la console Google SecOpsendpoint: 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.
- États-Unis :
Enregistrez le fichier de configuration.
- Après avoir modifié le fichier, enregistrez-le :
- Linux : appuyez sur
Ctrl+O, puis surEnter, puis surCtrl+X. - Windows : cliquez sur Fichier > Enregistrer.
- Linux : appuyez sur
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-collectorVérifiez que le service est en cours d'exécution :
sudo systemctl status observiq-otel-collectorRecherchez 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-collectorConsole Services :
- Appuyez sur
Win+R, saisissezservices.msc, puis appuyez sur Entrée. - Localisez le collecteur observIQ OpenTelemetry.
- Effectuez un clic droit, puis sélectionnez Redémarrer.
Vérifiez que le service est en cours d'exécution :
sc query observiq-otel-collectorRecherchez les erreurs dans les journaux :
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Appuyez sur
Configurer syslog dans MySQL
- Connectez-vous à l'hôte MySQL à l'aide de SSH.
Connectez-vous à la base de données MySQL :
mysql -u root -pVérifiez le plug-in d'audit
server_audit.so:show variables like 'plugin_dir';Si le plug-in est introuvable, installez-le :
install plugin server_audit soname 'server_audit.so';Vérifiez que le plug-in est installé et activé :
show plugins;Modifiez le fichier
/etc/my.cnfet 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_LOCAL6Vérifiez les variables d'audit :
show global variables like "server_audit%";Vérifiez que l'audit est activé :
Show global status like 'server_audit%';Modifiez le fichier
/etc/rsyslog.confpour 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.
- Remplacez
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.