Coletar registros do MySQL

Compatível com:

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

  1. Faça login no console do Google SecOps.
  2. Acesse Configurações do SIEM > Agentes de coleta.
  3. Baixe o arquivo de autenticação de ingestão.
  4. Salve o arquivo com segurança no sistema em que o agente do Bindplane será instalado.

Receber o ID de cliente do Google SecOps

  1. Faça login no console do Google SecOps.
  2. Acesse Configurações do SIEM > Perfil.
  3. 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

  1. Abra o prompt de comando ou o PowerShell como administrador.
  2. Execute este comando:

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. Aguarde a conclusão da instalação.

  4. Execute o seguinte comando para confirmar a instalação:

    sc query observiq-otel-collector
    

    O serviço vai aparecer como EM EXECUÇÃO.

Instalação do Linux

  1. Abra um terminal com privilégios de root ou sudo.
  2. Execute este comando:

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. Aguarde a conclusão da instalação.

  4. Execute o seguinte comando para confirmar a instalação:

    sudo systemctl status observiq-otel-collector
    

    O 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.yaml
    
  • Windows:

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

Editar o arquivo de configuração

  • Substitua todo o conteúdo de config.yaml pela 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.0 para detectar em todas as interfaces (recomendado)
      • A porta 514 é a porta padrão do syslog. Ela exige acesso root no Linux. Use 1514 para 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
    • customer_id: ID do cliente copiado do console do Google SecOps
    • endpoint: 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.

Salve o arquivo de configuração.

  • Depois de editar, salve o arquivo:
    • Linux: pressione Ctrl+O, Enter e Ctrl+X.
    • Windows: clique em Arquivo > Salvar.

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-collector
    
    1. Verifique se o serviço está em execução:

      sudo systemctl status observiq-otel-collector
      
    2. Verifique 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-collector
      
    • Console de serviços:

      1. Pressione Win+R, digite services.msc e pressione Enter.
      2. Localize o Coletor do OpenTelemetry da observIQ.
      3. Clique com o botão direito do mouse e selecione Reiniciar.
      4. Verifique se o serviço está em execução:

        sc query observiq-otel-collector
        
      5. Verifique se há erros nos registros:

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

Configurar o syslog no MySQL

  1. Faça login no host do MySQL usando SSH.
  2. Conecte-se ao banco de dados MySQL:

    mysql -u root -p
    
  3. Verifique o plug-in de auditoria server_audit.so:

    show variables like 'plugin_dir';
    
  4. Se o plug-in não for encontrado, instale-o:

    install plugin server_audit soname 'server_audit.so';
    
  5. Confirme se o plug-in está Instalado e Ativado:

    show plugins;
    
  6. Edite o arquivo /etc/my.cnf e 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_LOCAL6
    
  7. Verifique as variáveis de auditoria:

    show global variables like "server_audit%";
    
  8. Verifique se a auditoria está ativada:

    Show global status like 'server_audit%';
    
  9. Edite o arquivo /etc/rsyslog.conf para 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.
  10. 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.