Coletar registros do MySQL
Este documento explica como ingerir registros do MySQL no Google Security Operations usando o agente Bindplane.
O MySQL é um sistema de gerenciamento de banco de dados relacional que gera mensagens syslog para eventos de autenticação, execução de consultas, operações de banco de dados e entradas de trilha de auditoria. O analisador extrai campos de registros de auditoria formatados em syslog e os mapeia para o modelo de dados unificado (UDM).
Antes de começar
Verifique se você tem os pré-requisitos a seguir:
- Uma instância do Google SecOps
- Windows Server 2016 ou mais recente ou host Linux com
systemd - Conectividade de rede entre o agente do Bindplane e o servidor MySQL
- Se estiver executando por trás de um proxy, verifique se as portas do firewall estão abertas de acordo com os requisitos do agente Bindplane.
- Acesso SSH ao host do MySQL com privilégios root ou sudo
Receber o arquivo de autenticação de ingestão do Google SecOps
- Faça login no console do Google SecOps.
- Acesse Configurações do SIEM > Agentes de coleta.
- Baixe o arquivo de autenticação de ingestão.
Salve o arquivo com segurança no sistema em que o agente do Bindplane será instalado.
Receber o ID de cliente do Google SecOps
- Faça login no console do Google SecOps.
- Acesse Configurações do SIEM > Perfil.
Copie e salve o ID do cliente na seção Detalhes da organização.
Instalar o agente do BindPlane
Instale o agente do Bindplane no seu sistema operacional Windows ou Linux de acordo com as instruções a seguir.
Instalação do Windows
- Abra o prompt de comando ou o PowerShell como administrador.
Execute este comando:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietAguarde a conclusão da instalação.
Execute o seguinte comando para confirmar a instalação:
sc query observiq-otel-collectorO serviço vai aparecer como EM EXECUÇÃO.
Instalação do Linux
- Abra um terminal com privilégios de root ou sudo.
Execute este comando:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shAguarde a conclusão da instalação.
Execute o seguinte comando para confirmar a instalação:
sudo systemctl status observiq-otel-collectorO serviço vai aparecer como ativo (em execução).
Outros recursos de instalação
Para mais opções de instalação e solução de problemas, consulte o guia de instalação do agente do Bindplane.
Configurar o agente do Bindplane para ingerir syslog e enviar ao Google SecOps
Localizar o arquivo de configuração
Linux:
sudo nano /opt/observiq-otel-collector/config.yamlWindows:
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Editar o arquivo de configuração
Substitua todo o conteúdo de
config.yamlpela seguinte configuração: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
Parâmetros de configuração
Substitua os seguintes marcadores de posição:
Configuração do receptor:
listen_address: endereço IP e porta a serem detectados:0.0.0.0para detectar em todas as interfaces (recomendado)- A porta
514é a porta padrão do syslog. Ela exige acesso root no Linux. Use1514para acesso não root.
Configuração do exportador:
creds_file_path: caminho completo para o arquivo de autenticação de ingestão:- Linux:
/etc/bindplane-agent/ingestion-auth.json - Windows:
C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
- Linux:
customer_id: ID do cliente copiado do console do Google SecOpsendpoint: URL do endpoint regional:- EUA:
malachiteingestion-pa.googleapis.com - Europa:
europe-malachiteingestion-pa.googleapis.com - Ásia:
asia-southeast1-malachiteingestion-pa.googleapis.com - Consulte a lista completa em Endpoints regionais.
- EUA:
Salve o arquivo de configuração.
- Depois de editar, salve o arquivo:
- Linux: pressione
Ctrl+O,EntereCtrl+X. - Windows: clique em Arquivo > Salvar.
- Linux: pressione
Reinicie o agente do Bindplane para aplicar as mudanças
Para reiniciar o agente do Bindplane no Linux, execute o seguinte comando:
sudo systemctl restart observiq-otel-collectorVerifique se o serviço está em execução:
sudo systemctl status observiq-otel-collectorVerifique se há erros nos registros:
sudo journalctl -u observiq-otel-collector -f
Para reiniciar o agente do Bindplane no Windows, escolha uma das seguintes opções:
Prompt de comando ou PowerShell como administrador:
net stop observiq-otel-collector && net start observiq-otel-collectorConsole de serviços:
- Pressione
Win+R, digiteservices.msce pressione Enter. - Localize o Coletor do OpenTelemetry da observIQ.
- Clique com o botão direito do mouse e selecione Reiniciar.
Verifique se o serviço está em execução:
sc query observiq-otel-collectorVerifique se há erros nos registros:
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Pressione
Configurar o syslog no MySQL
- Faça login no host do MySQL usando SSH.
Conecte-se ao banco de dados MySQL:
mysql -u root -pVerifique o plug-in de auditoria
server_audit.so:show variables like 'plugin_dir';Se o plug-in não for encontrado, instale-o:
install plugin server_audit soname 'server_audit.so';Confirme se o plug-in está Instalado e Ativado:
show plugins;Edite o arquivo
/etc/my.cnfe ative as seguintes configurações de auditoria: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_LOCAL6Verifique as variáveis de auditoria:
show global variables like "server_audit%";Verifique se a auditoria está ativada:
Show global status like 'server_audit%';Edite o arquivo
/etc/rsyslog.confpara ativar o encaminhamento via UDP:*.* @@<bindplane-agent-ip>:<bindplane-agent-port>- Substitua
<bindplane-agent-ip>e<bindplane-agent-port>pela configuração do agente do Bindplane.
- Substitua
Reinicie o serviço do MySQL:
/etc/init.d/mysqld restart
Tabela de mapeamento do UDM
| Campo de registro | Mapeamento de UDM | Lógica |
|---|---|---|
| ação | read_only_udm.metadata.event_type | Se o valor for Created, será FILE_CREATION. Se for Deleted, será FILE_DELETION. Caso contrário, nenhuma mudança. |
| banco_de_dados | read_only_udm.target.resource.parent | |
| db_hostname | read_only_udm.target.hostname | |
| db_user | read_only_udm.target.user.userid | |
| descrição | read_only_udm.security_result.description | |
| error_details | Esta é uma variável temporária. Ignore-a. | |
| error_level | read_only_udm.security_result.severity | Se o valor for error, será ERROR. Se for warning, será MEDIUM. Se for note, será INFORMATIONAL. Caso contrário, não haverá mudança. |
| 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 | |
| nome do host | read_only_udm.principal.hostname | |
| inner_message | read_only_udm.security_result.description | |
| resumo | read_only_udm.metadata.product_event_type | |
| tabela | read_only_udm.target.resource.name | |
| table_not_found | Esta é uma variável temporária. Ignore-a. | |
| timestamp | read_only_udm.metadata.event_timestamp | |
| read_only_udm.extensions.auth.type | Valor estático: MACHINE |
|
| read_only_udm.metadata.event_type | Valor estático: USER_LOGIN, GENERIC_EVENT, STATUS_UPDATE, FILE_CREATION, FILE_DELETION |
|
| read_only_udm.metadata.log_type | Valor estático: MYSQL |
|
| read_only_udm.metadata.product_name | Valor estático: MySQL |
|
| read_only_udm.metadata.vendor_name | Valor estático: Oracle Corporation |
|
| read_only_udm.security_result.action | Valor estático: BLOCK |
|
| read_only_udm.target.resource.resource_type | Valor estático: DATABASE, TABLE |
|
properties.event_time |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
properties.ip |
event.idm.read_only_udm.principal.ip e event.idm.read_only_udm.principal.asset.ip |
Mapeado do registro de mudanças |
properties.user |
event.idm.read_only_udm.principal.user.userid |
Mapeado do registro de mudanças |
properties.error_code |
event.idm.read_only_udm.security_result.description |
Mapeado do registro de mudanças |
properties.event_subclass |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.is_aad_auth |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
category |
event.idm.read_only_udm.metadata.product_event_type |
Mapeado do registro de mudanças |
ServerType |
event.idm.read_only_udm.target.application |
Mapeado do registro de mudanças |
target_app |
event.idm.read_only_udm.target.application |
Mapeado do registro de mudanças |
properties.start_time |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
ts |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
time |
event.idm.read_only_udm.metadata.collected_timestamp |
Mapeado do registro de mudanças |
properties.server_id |
event.idm.read_only_udm.target.asset.asset_id |
Mapeado do registro de mudanças |
properties.thread_id |
event.idm.read_only_udm.principal.process.pid |
Mapeado do registro de mudanças |
user_id |
event.idm.read_only_udm.principal.user.userid |
Mapeado do registro de mudanças |
p_host |
event.idm.read_only_udm.principal.hostname |
Mapeado do registro de mudanças |
p_host |
event.idm.read_only_udm.principal.asset.hostname |
Mapeado do registro de mudanças |
properties.db |
event.idm.read_only_udm.target.resource.name |
Mapeado do registro de mudanças |
resourceId |
event.idm.read_only_udm.target.resource.product_object_id |
Mapeado do registro de mudanças |
operationName |
event.idm.read_only_udm.metadata.description |
Mapeado do registro de mudanças |
location |
event.idm.read_only_udm.target.location.name |
Mapeado do registro de mudanças |
properties.host |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.last_insert_id |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.insert_id |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.sql_text |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.rows_examined |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.rows_sent |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.lock_time |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.query_time |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.replication_set_role |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
properties.event_class |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
csv_principal_hostname |
event.idm.read_only_udm.principal.ip e event.idm.read_only_udm.principal.asset.ip |
Mapeado do registro de mudanças |
csv_hostname |
event.idm.read_only_udm.target.hostname e event.idm.read_only_udm.target.asset.hostname |
Mapeado do registro de mudanças |
csv_principal_hostname |
event.idm.read_only_udm.principal.hostname e event.idm.read_only_udm.principal.asset.hostname |
Mapeado do registro de mudanças |
ts |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
csv_query_id |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
csv_mysql |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
account_host |
event.idm.read_only_udm.principal.resource.attribute.labels |
Mapeado do registro de mudanças |
login_proxy |
event.idm.read_only_udm.principal.resource.attribute.labels |
Mapeado do registro de mudanças |
login_os |
event.idm.read_only_udm.principal.resource.attribute.labels |
Mapeado do registro de mudanças |
arg |
event.idm.read_only_udm.principal.resource.attribute.labels |
Mapeado do registro de mudanças |
startup_data_server_id |
event.idm.read_only_udm.principal.resource.product_object_id |
Mapeado do registro de mudanças |
startup_data_os_version |
event.idm.read_only_udm.principal.platform_version |
Mapeado do registro de mudanças |
startup_data_mysql_version |
event.idm.read_only_udm.metadata.product_version |
Mapeado do registro de mudanças |
arg |
event.idm.read_only_udm.principal.process.command_line |
Mapeado do registro de mudanças |
csv_mysql_sql_query |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
hostname |
event.idm.read_only_udm.intermediary.hostname e event.idm.read_only_udm.intermediary.asset.hostname |
Mapeado do registro de mudanças |
id |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
login.proxy |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
connection_data.connection_type |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
connection_data.status |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
login.os |
event.idm.read_only_udm.principal.platform_version |
Mapeado do registro de mudanças |
account.host |
event.idm.read_only_udm.target.hostname e event.idm.read_only_udm.target.asset.hostname |
Mapeado do registro de mudanças |
connection_data.db |
event.idm.read_only_udm.target.application |
Mapeado do registro de mudanças |
mysql_description |
event.idm.read_only_udm.metadata.description |
Mapeado do registro de mudanças |
mysql_errno |
event.idm.read_only_udm.metadata.product_log_id |
Mapeado do registro de mudanças |
mysql_version |
event.idm.read_only_udm.metadata.product_version |
Mapeado do registro de mudanças |
process_path |
event.idm.read_only_udm.principal.process.file.full_path |
Mapeado do registro de mudanças |
mysql_port |
event.idm.read_only_udm.principal.port |
Mapeado do registro de mudanças |
status |
event.idm.read_only_udm.security_result.summary |
Mapeado do registro de mudanças |
error_level |
event.idm.read_only_udm.security_result.severity_details |
Mapeado do registro de mudanças |
mysql_thread_id |
event.idm.read_only_udm.network.session_id |
Mapeado do registro de mudanças |
mysql_socket |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
log_level |
event.idm.read_only_udm.additional.fields |
Mapeado do registro de mudanças |
mysql_timestamp |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
event_date |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
event_time |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
csv_timestamp |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
mysql_action |
event.idm.read_only_udm.metadata.product_event_type |
Mapeado do registro de mudanças |
log_category |
event.idm.read_only_udm.metadata.product_event_type |
Mapeado do registro de mudanças |
csv_mysql_action |
event.idm.read_only_udm.metadata.product_event_type |
Mapeado do registro de mudanças |
csv_mysql_connection_type |
event.idm.read_only_udm.metadata.product_event_type |
Mapeado do registro de mudanças |
event_message |
event.idm.read_only_udm.metadata.description |
Mapeado do registro de mudanças |
resolution_error |
event.idm.read_only_udm.metadata.description |
Mapeado do registro de mudanças |
component |
event.idm.read_only_udm.principal.application |
Mapeado do registro de mudanças |
mysql_hostname |
event.idm.read_only_udm.principal.ip e event.idm.read_only_udm.principal.asset.ip |
Mapeado do registro de mudanças |
csv_hostname_ip |
event.idm.read_only_udm.principal.ip e event.idm.read_only_udm.principal.asset.ip |
Mapeado do registro de mudanças |
mysql_username |
event.idm.read_only_udm.principal.user.userid |
Mapeado do registro de mudanças |
csv_username |
event.idm.read_only_udm.principal.user.userid |
Mapeado do registro de mudanças |
csv_target_hostname |
event.idm.read_only_udm.target.hostname e event.idm.read_only_udm.target.asset.hostname |
Mapeado do registro de mudanças |
csv_database_name |
event.idm.read_only_udm.target.resource.name |
Mapeado do registro de mudanças |
mysql_sql_query |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
csv_connection_id |
event.idm.read_only_udm.network.session_id |
Mapeado do registro de mudanças |
mysql_message_id |
event.idm.read_only_udm.security_result.rule_id |
Mapeado do registro de mudanças |
target_mysql_hostname |
event.idm.read_only_udm.target.hostname e event.idm.read_only_udm.target.asset.hostname |
Mapeado do registro de mudanças |
csv_mysql_connection_type |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
login.ip |
event.idm.read_only_udm.principal.ip |
Mapeado do registro de mudanças |
login.ip |
event.idm.read_only_udm.principal.asset.ip |
Mapeado do registro de mudanças |
login.user |
event.idm.read_only_udm.principal.user.userid |
Mapeado do registro de mudanças |
account.user |
event.idm.read_only_udm.target.user.userid |
Mapeado do registro de mudanças |
inter_host |
event.idm.read_only_udm.intermediary.hostname |
Mapeado do registro de mudanças |
target_host |
event.idm.read_only_udm.target.hostname |
Mapeado do registro de mudanças |
target_host |
event.idm.read_only_udm.target.asset.hostname |
Mapeado do registro de mudanças |
target_ip |
event.idm.read_only_udm.target.ip |
Mapeado do registro de mudanças |
target_ip |
event.idm.read_only_udm.target.asset.ip |
Mapeado do registro de mudanças |
connection_id |
event.idm.read_only_udm.network.session_id |
Mapeado do registro de mudanças |
general_data.command |
event.idm.read_only_udm.target.process.command_line |
Mapeado do registro de mudanças |
general_data.query |
event.idm.read_only_udm.security_result.summary |
Mapeado do registro de mudanças |
connection_data.connection_type |
event.idm.read_only_udm.network.ip_protocol |
Mapeado do registro de mudanças |
general_data.sql_command |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
event_data |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
general_data.status |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
class |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
Status |
event.idm.read_only_udm.security_result.detection_fields |
Mapeado do registro de mudanças |
sql_query |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
value |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
num |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
ns |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
itemid |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
value_min |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
value_avg |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
value_max |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
query_id |
event.idm.read_only_udm.target.resource.attribute.labels |
Mapeado do registro de mudanças |
clock |
event.idm.read_only_udm.metadata.event_timestamp |
Mapeado do registro de mudanças |
path |
principal.file.full_path |
Mapeado do registro de mudanças |
logtype |
metadata.product_event_type |
Mapeado do registro de mudanças |
Registro de alterações
Ver o registro de alterações deste analisador
Precisa de mais ajuda? Receba respostas de membros da comunidade e profissionais do Google SecOps.