Coletar registros de VPN da F5
Este documento explica como ingerir registros de VPN da F5 no Google Security Operations usando o agente do Bindplane.
O F5 BIG-IP Access Policy Manager (APM) é uma solução de VPN e gerenciamento de acesso que gera mensagens syslog para autenticação de usuários, gerenciamento de sessões, avaliação de políticas, estabelecimento de túneis e eventos de acesso à rede. O analisador extrai campos de registros 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 appliance F5 BIG-IP
- Se você 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 privilegiado ao tmsh do F5 BIG-IP (versão 11.x ou mais recente)
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 /etc/bindplane-agent/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/f5_vpn: compression: gzip creds_file_path: '/etc/bindplane-agent/ingestion-auth.json' customer_id: '<customer_id>' endpoint: malachiteingestion-pa.googleapis.com log_type: F5_VPN raw_log_field: body service: pipelines: logs/f5_vpn_to_chronicle: receivers: - udplog exporters: - chronicle/f5_vpn
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 (requer raiz no Linux; use1514para não raiz)
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 em 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 encaminhamento do syslog no F5 BIG-IP APM
- Conecte-se à linha de comando do F5 BIG-IP.
Abra o shell tmsh:
tmshConfigure um servidor Syslog remoto executando o seguinte comando:
modify sys syslog remote-servers add { <Name> { host <bindplane-ip> remote-port <bindplane-port> } }Substitua:
<Name>: um nome exclusivo para esse destino do syslog (por exemplo,bindplane_server).<bindplane-ip>: o endereço IP do host do agente do Bindplane.<bindplane-port>: a porta configurada no receptor do agente do Bindplane (padrão:514).
Salve a configuração:
save sys config partitions all
Tabela de mapeamento do UDM
| Campo de registro | Mapeamento do UDM | Lógica |
|---|---|---|
cmd_data |
principal.process.command_line |
O valor é extraído do campo "msg". |
errdefs_msgno |
additional.fields.errdefs_msgno.string_value |
O valor é extraído do campo "msg". |
event_time |
metadata.event_timestamp |
O valor é analisado e convertido em um carimbo de data/hora |
hostname |
principal.hostname,, observer.hostname,, principal.asset.hostname,, observer.asset.hostname, |
O valor é extraído do campo de mensagem e usado para preencher os campos de nome do host na UDM. Também usado para preencher o campo "hostip". |
msg |
security_result.description |
O valor é extraído do campo "message" e usado para preencher o campo "description" no objeto "security_result". |
prin_ip |
principal.ip,, principal.asset.ip |
O valor é extraído do campo de mensagem e usado para preencher os campos de endereço IP na UDM. |
additional.fields.Canonical_Info.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.IDP.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.Plugin_Support.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.SMB, Stage.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.SP.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.Timezone.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.Tunnel, Type.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.UI_Mode.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.Version.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.from_rule_item.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.policy_result.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.ppp_id.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.resource.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.rule.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.server_vip_ip.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.server_vip_name.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.to_rule_item.string_value |
O valor é derivado da mensagem de registro. | |
additional.fields.tunnel_resource.string_value |
O valor é derivado da mensagem de registro. | |
metadata.description |
O valor é derivado da mensagem de registro. | |
metadata.event_type |
O valor é codificado no código do analisador para alguns eventos e derivado da mensagem de registro para outros. | |
metadata.log_type |
O valor é definido como o tipo de lote. | |
metadata.product_event_type |
O valor é derivado da mensagem de registro. | |
metadata.product_name |
O valor está fixado no código do analisador. | |
metadata.vendor_name |
O valor está fixado no código do analisador. | |
network.application_protocol |
O valor é derivado da mensagem de registro. | |
network.direction |
O valor é derivado da mensagem de registro. | |
network.http.method |
O valor é derivado da mensagem de registro. | |
network.http.parsed_user_agent |
O valor é derivado do campo "network.http.user_agent". | |
network.http.referral_url |
O valor é derivado da mensagem de registro. | |
network.http.response_code |
O valor é derivado da mensagem de registro. | |
network.http.user_agent |
O valor é derivado da mensagem de registro. | |
network.ip_protocol |
O valor é derivado da mensagem de registro. | |
network.received_bytes |
O valor é derivado da mensagem de registro. | |
network.sent_bytes |
O valor é derivado da mensagem de registro. | |
network.session_id |
O valor é derivado da mensagem de registro. | |
network.tls.cipher |
O valor é derivado da mensagem de registro. | |
network.tls.version |
O valor é derivado da mensagem de registro. | |
observer.asset.hostname |
O valor é definido como o campo de nome do host. | |
observer.asset.ip |
O valor é definido como o campo "hostip". | |
observer.hostname |
O valor é definido como o campo de nome do host. | |
observer.ip |
O valor é definido como o campo "hostip". | |
principal.application |
O valor é derivado da mensagem de registro. | |
principal.asset.hostname |
O valor é definido como o campo de nome do host. | |
principal.asset.ip |
O valor é definido como o campo "hostip" ou "prin_ip", se existir. | |
principal.asset.product_object_id |
O valor é derivado da mensagem de registro. | |
principal.hostname |
O valor é definido como o campo de nome do host. | |
principal.ip |
O valor é definido como o campo "hostip" ou "prin_ip", se existir. | |
principal.location.country_or_region |
O valor é derivado da mensagem de registro. | |
principal.platform |
O valor é derivado da mensagem de registro. | |
principal.port |
O valor é derivado da mensagem de registro. | |
principal.process.command_line |
O valor é derivado da mensagem de registro. | |
principal.process.pid |
O valor é derivado da mensagem de registro. | |
principal.resource.name |
O valor é derivado da mensagem de registro. | |
principal.resource.type |
O valor é codificado no código do analisador para alguns eventos e derivado da mensagem de registro para outros. | |
principal.user.email_addresses |
O valor é derivado da mensagem de registro. | |
principal.user.userid |
O valor é derivado da mensagem de registro. | |
security_result.action |
O valor é derivado da mensagem de registro. | |
security_result.description |
O valor é derivado da mensagem de registro. | |
security_result.rule_name |
O valor é derivado da mensagem de registro. | |
security_result.severity |
O valor é derivado da mensagem de registro. | |
security_result.severity_details |
O valor é derivado da mensagem de registro. | |
security_result.summary |
O valor é derivado da mensagem de registro. | |
src.ip |
O valor é derivado da mensagem de registro. | |
src.location.country_or_region |
O valor é derivado da mensagem de registro. | |
src.port |
O valor é derivado da mensagem de registro. | |
target.asset.hostname |
O valor é derivado da mensagem de registro. | |
target.asset.ip |
O valor é derivado da mensagem de registro. | |
target.hostname |
O valor é derivado da mensagem de registro. | |
target.ip |
O valor é derivado da mensagem de registro. | |
target.port |
O valor é derivado da mensagem de registro. | |
target.process.command_line |
O valor é derivado da mensagem de registro. | |
target.process.pid |
O valor é derivado da mensagem de registro. | |
target.resource.id |
O valor é derivado da mensagem de registro. | |
target.url |
O valor é derivado da mensagem de registro. | |
target.user.userid |
O valor é derivado da mensagem de registro. |
Precisa de mais ajuda? Receba respostas de membros da comunidade e profissionais do Google SecOps.