Fortinet FortiClient 로그 수집

다음에서 지원:

이 문서에서는 Bindplane 에이전트를 사용하여 Fortinet FortiClient 로그를 Google Security Operations로 수집하는 방법을 설명합니다.

FortiClient는 Windows, macOS, Linux, Chromebook 엔드포인트에 바이러스 백신, 웹 필터링, VPN, 취약점 검사, 애플리케이션 방화벽 기능을 제공하는 엔드포인트 보안 솔루션입니다. FortiClient는 보안 정책과 구성 프로필을 엔드포인트로 푸시하는 FortiClient EMS (엔드포인트 관리 서버)를 통해 중앙에서 관리됩니다.

시작하기 전에

다음 기본 요건이 충족되었는지 확인합니다.

  • Google SecOps 인스턴스
  • Windows Server 2016 이상 또는 systemd가 있는 Linux 호스트
  • Bindplane 에이전트와 FortiClient 엔드포인트 간 네트워크 연결
  • 프록시 뒤에서 실행하는 경우 Bindplane 에이전트 요구사항에 따라 방화벽 포트가 열려 있는지 확인합니다.
  • FortiClient EMS 관리 콘솔에 대한 권한이 있는 액세스
  • 라이선스가 부여된 FortiClient 엔드포인트가 있는 FortiClient EMS 버전 7.0 이상

Google SecOps 수집 인증 파일 가져오기

  1. Google SecOps 콘솔에 로그인합니다.
  2. SIEM 설정 > 수집 에이전트로 이동합니다.
  3. 다운로드를 클릭하여 수집 인증 파일을 다운로드합니다.
  4. Bindplane 에이전트가 설치될 시스템에 파일을 안전하게 저장합니다.

Google SecOps 고객 ID 가져오기

  1. Google SecOps 콘솔에 로그인합니다.
  2. SIEM 설정 > 프로필로 이동합니다.
  3. 조직 세부정보 섹션에서 고객 ID를 복사하여 저장합니다.

Bindplane 에이전트 설치

다음 안내에 따라 Windows 또는 Linux 운영체제에 Bindplane 에이전트를 설치합니다.

Windows 설치

  1. 명령 프롬프트 또는 PowerShell을 관리자로 엽니다.
  2. 다음 명령어를 실행합니다.

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. 설치가 완료될 때까지 기다립니다.

  4. 다음을 실행하여 설치를 확인합니다.

    sc query observiq-otel-collector
    

서비스가 실행 중으로 표시되어야 합니다.

Linux 설치

  1. 루트 또는 sudo 권한으로 터미널을 엽니다.
  2. 다음 명령어를 실행합니다.

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. 설치가 완료될 때까지 기다립니다.

  4. 다음을 실행하여 설치를 확인합니다.

    sudo systemctl status observiq-otel-collector
    

서비스가 active (running)으로 표시되어야 합니다.

추가 설치 리소스

추가 설치 옵션 및 문제 해결은 Bindplane 에이전트 설치 가이드를 참고하세요.

syslog를 수집하여 Google SecOps로 전송하도록 Bindplane 에이전트 구성

구성 파일 찾기

Linux:

sudo nano /etc/bindplane-agent/config.yaml

Windows:

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

구성 파일 설정

config.yaml의 전체 내용을 다음 구성으로 바꿉니다.

receivers:
    udplog:
    listen_address: "0.0.0.0:514"

exporters:
    chronicle/forticlient:
    compression: gzip
    creds_file_path: '/etc/bindplane-agent/ingestion-auth.json'
    customer_id: 'your-customer-id-here'
    endpoint: malachiteingestion-pa.googleapis.com
    log_type: FORTINET_FORTICLIENT
    raw_log_field: body
    ingestion_labels:
        env: production
        source: forticlient

service:
    pipelines:
    logs/forticlient_to_chronicle:
        receivers:
        - udplog
        exporters:
        - chronicle/forticlient

구성 매개변수

다음 자리표시자를 바꿉니다.

수신기 구성:

  • listen_address: 리슨할 IP 주소 및 포트입니다. 0.0.0.0:514를 사용하여 포트 514의 모든 인터페이스에서 수신 대기합니다.

내보내기 도구 구성:

  • creds_file_path: 수집 인증 파일의 전체 경로입니다.
    • Linux: /etc/bindplane-agent/ingestion-auth.json
    • Windows: C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
  • customer_id: Google SecOps 콘솔의 고객 ID
  • endpoint: 리전 엔드포인트 URL:
    • 미국: malachiteingestion-pa.googleapis.com
    • 유럽: europe-malachiteingestion-pa.googleapis.com
    • 아시아: asia-southeast1-malachiteingestion-pa.googleapis.com
    • 전체 목록은 리전 엔드포인트를 참고하세요.
  • log_type: FORTINET_FORTICLIENT
  • ingestion_labels: YAML 형식의 선택적 라벨

구성 파일 저장

수정 후 파일을 저장합니다.

  • Linux: Ctrl+O, Enter, Ctrl+X 순으로 누릅니다.
  • Windows: 파일 > 저장을 클릭합니다.

변경사항을 적용하려면 Bindplane 에이전트를 다시 시작하세요.

  • Linux

    sudo systemctl restart observiq-otel-collector
    
    1. 서비스가 실행 중인지 확인합니다.

      sudo systemctl status observiq-otel-collector
      
    2. 로그에서 오류를 확인합니다.

      sudo journalctl -u observiq-otel-collector -f
      
  • Windows

    다음 옵션 중 하나를 선택합니다.

    • 명령 프롬프트 또는 PowerShell을 관리자로 사용합니다.

      net stop observiq-otel-collector && net start observiq-otel-collector
      
    • 서비스 콘솔 사용:

      1. Win+R를 누르고 services.msc를 입력한 다음 Enter 키를 누릅니다.
      2. observIQ OpenTelemetry Collector를 찾습니다.
      3. 마우스 오른쪽 버튼을 클릭하고 다시 시작을 선택합니다.

      4. 서비스가 실행 중인지 확인합니다.

        sc query observiq-otel-collector
        
      5. 로그에서 오류를 확인합니다.

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

로그를 Bindplane 에이전트로 보내도록 FortiClient 엔드포인트 로깅 구성

FortiClient 엔드포인트 로깅은 XML 구성으로 엔드포인트 프로필을 수정하여 FortiClient EMS를 통해 중앙에서 구성됩니다. EMS는 로깅 구성을 FortiClient 엔드포인트로 푸시하고, 엔드포인트는 로그를 Bindplane 에이전트 syslog 리스너로 직접 전송합니다.

FortiClient EMS에 로그인

  1. FortiClient EMS 웹 콘솔에 로그인합니다.
  2. 엔드포인트 프로필 > 프로필 관리로 이동합니다.

엔드포인트 프로필 수정 또는 만들기

  1. 기존 프로필을 선택하여 수정하거나 추가를 클릭하여 새 프로필을 만듭니다.
  2. 프로필 이름 필드에 설명이 포함된 이름을 입력합니다 (예: Chronicle-Logging-Profile).
  3. 고급을 클릭합니다.
  4. XML 구성 탭을 클릭합니다.
  5. 수정을 클릭합니다.

XML에서 원격 로깅 구성

EMS에 두 개의 창이 표시됩니다. 오른쪽 창을 사용하여 XML 구성을 수정합니다.

<system> 내에서 <log_settings> 섹션을 찾습니다. 이 섹션이 없으면 추가합니다. <log_settings> 내에서 <remote_logging> 섹션을 찾아 추가하고 다음과 같이 구성합니다.

<forticlient_configuration>
    <system>
    <log_settings>
        <onnet_local_logging>1</onnet_local_logging>
        <level>6</level>
        <log_events>ipsecvpn,sslvpn,scheduler,update,firewall,av,proxy,shield,webfilter,endpoint,fssoma,configd,vuln,sandboxing,antiexploit</log_events>
        <remote_logging>
        <log_upload_enabled>1</log_upload_enabled>
        <log_protocol>syslog</log_protocol>
        <netlog_server>192.168.1.100</netlog_server>
        <netlog_categories>7</netlog_categories>
        <log_upload_freq_minutes>5</log_upload_freq_minutes>
        </remote_logging>
    </log_settings>
    </system>
</forticlient_configuration>

구성 매개변수:

  • <log_upload_enabled>: 1로 설정하여 원격 로깅을 사용 설정합니다.
  • <log_protocol>: syslog 서버에 로그를 전송하려면 syslog로 설정합니다. 대신 faz를 사용하여 로그를 FortiAnalyzer로 전송하세요.
  • <netlog_server>: Bindplane 에이전트 호스트의 IP 주소를 입력합니다 (예: 192.168.1.100). 이 매개변수는 <log_protocol>syslog로 설정된 경우에만 사용됩니다.
  • <netlog_categories>: 업로드할 로그 카테고리의 비트마스크를 입력합니다.
    • 1 = 트래픽 로그
    • 2 = 취약점 로그
    • 4 = 이벤트 로그
    • 7 = 모든 카테고리 (1 + 2 + 4)
  • <log_upload_freq_minutes>: 로그 업로드 빈도를 분 단위로 입력합니다 (예: 5분마다 5).
  • <level>: FortiClient 로깅 수준입니다. 다음 중 하나를 입력합니다.
    • 0 = Emergency
    • 1 = Alert
    • 2 = 심각
    • 3 = 오류
    • 4 = 경고
    • 5 = 알림
    • 6 = 정보 (권장)
    • 7 = 디버그
  • <log_events>: 로깅할 FortiClient 이벤트 또는 프로세스를 쉼표로 구분한 목록입니다. 캡처하려는 이벤트 (예: ipsecvpn,sslvpn,firewall,av,webfilter,endpoint)를 포함합니다.

프로필 저장

  1. XML 테스트를 클릭하여 XML 구성의 유효성을 검사합니다.
  2. 저장을 클릭하여 프로필을 저장합니다.

엔드포인트에 프로필 적용

  1. 엔드포인트 정책 > 정책 관리로 이동합니다.
  2. 기존 정책을 선택하거나 추가를 클릭하여 새 정책을 만듭니다.
  3. 프로필 드롭다운에서 생성하거나 수정한 프로필을 선택합니다.
  4. 엔드포인트 그룹 섹션에서 정책을 적용할 엔드포인트 그룹을 선택합니다.
  5. 저장을 클릭합니다.

EMS는 다음 원격 분석 통신을 통해 프로필 구성을 엔드포인트로 푸시합니다. FortiClient 엔드포인트가 Bindplane 에이전트 syslog 리스너에 로그를 전송하기 시작합니다.

로그 전달 확인

  1. Bindplane 에이전트 호스트에서 에이전트 로그를 확인하여 로그가 수신되고 있는지 확인합니다.

    Linux:

    sudo journalctl -u observiq-otel-collector -f
    

    Windows:

    type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
    
  2. FortiClient 엔드포인트에서 FortiClient 로그를 확인하여 원격 로깅이 사용 설정되어 있는지 확인합니다.

    Windows:

    C:\Program Files\Fortinet\FortiClient\logs\
    

    macOS:

    /Library/Application Support/Fortinet/FortiClient/logs/
    

    Linux:

    /var/log/forticlient/
    
  3. Google SecOps 콘솔에서 FortiClient 로그가 수집되고 있는지 확인합니다.

    • 검색으로 이동합니다.
    • FortiClient 로그의 검색어를 입력합니다 (예: metadata.log_type = "FORTINET_FORTICLIENT").
    • 로그가 검색 결과에 표시되는지 확인합니다.

UDM 매핑 테이블

로그 필드 UDM 매핑 논리
emsserial, devid, usingpolicy, itime, fctsn, logver, site, fctver, browsetime, event_id, SubjectUserName, SubjectLogonId, ThreadID additional.fields 각 필드의 키와 값으로 생성된 라벨이 additional.fields로 병합됨
타임스탬프 metadata.collected_timestamp UNIX 타임스탬프로 파싱됨
ts metadata.event_timestamp 'MMM d HH:mm:ss', 'MMM d HH:mm:ss', 'yyyy-MM-dd HH:mm:ss' 형식을 사용하여 날짜 필터로 파싱됨
deviceip, client_ip, devicemac, hostname, user, uid metadata.event_type 사용자/uid가 있고 머신 ID가 있으면 USER_RESOURCE_ACCESS로 설정하고, 머신 ID가 있으면 USER_UNCATEGORIZED로 설정하고, 그렇지 않으면 GENERIC_EVENT로 설정합니다.
eventtype metadata.product_event_type 값이 직접 복사됨
id metadata.product_log_id 문자열로 변환됨, 값이 복사됨
서비스 network.application_protocol 대문자로 변환한 후 목록과 일치하는 경우 사전 정의된 프로토콜로 설정합니다 (예: '22', 'SSH', 'SSHD'의 경우 'SSH', '80', '8080', 'HTTP'의 경우 'HTTP'), 확장 목록에 있는 경우 서비스, 그 외의 경우 비어 있음
direction network.direction (?i)inbound와 일치하는 경우 INBOUND로 설정하고 (?i)outbound와 일치하는 경우 OUTBOUND로 설정합니다.
proto network.ip_protocol proto == '6'인 경우 'TCP'로 설정
rcvdbyte network.received_bytes uint로 변환, 비어 있지 않거나 0이 아닌 경우 값이 복사됨
sentbyte network.sent_bytes uint로 변환, 비어 있지 않거나 0이 아닌 경우 값이 복사됨
sessionid network.session_id 값이 직접 복사됨
pcdomain principal.administrative_domain 값이 직접 복사됨
srcproduct principal.application 값이 직접 복사됨
호스트 이름 principal.hostname 값이 직접 복사됨
deviceip, client_ip principal.ip 비어 있지 않은 경우 deviceip의 값, 그렇지 않고 유효한 IP인 경우 client_ip의 값
devicemac principal.mac MAC 형식으로 변환, 유효한 경우 값이 복사됨
os, source principal.platform os/source가 (?i)windows와 일치하면 WINDOWS로 설정하고, (?i)mac|ios와 일치하면 MAC으로 설정하고, (?i)linux와 일치하면 LINUX로 설정합니다.
source_ver principal.platform_version 값이 직접 복사됨
srcport principal.port 정수로 변환됨, 값이 복사됨
ProcessId principal.process.pid 값이 직접 복사됨
srcname, source_type, type principal.resource.attribute.labels 각 필드의 키와 값으로 생성된 라벨이 attribute.labels로 병합됨
devname principal.resource.name 값이 직접 복사됨
ProviderGuid principal.resource.product_object_id 값이 직접 복사됨
하위 유형 principal.resource.resource_subtype 값이 직접 복사됨
url principal.url 값이 직접 복사됨
uid, fctuid principal.user.product_object_id 비어 있지 않으면 uid의 값, 그렇지 않으면 fctuid
사용자 principal.user.user_display_name 값이 직접 복사됨
사용자 principal.user.userid 값이 직접 복사됨
SubjectUserSid principal.user.windows_sid SID 정규식과 일치하는 경우 값이 복사됨
utmaction security_result.action [accept,allow,passthrough,pass,permit,detected]에 있으면 ALLOW로 설정하고, [deny,dropped,blocked,block]에 있으면 BLOCK으로 설정하고, 그 외의 경우에는 UNKNOWN_ACTION으로 설정합니다.
utmevent security_result.category_details 값이 직접 복사됨
utmaction security_result.description 'utmaction:'으로 설정
userinitiated security_result.detection_fields 'userinitiated' 키와 userinitiated에서 가져온 값으로 생성된 라벨이 병합됨
레벨 security_result.severity level == 'info'인 경우 INFORMATIONAL로 설정
위협 security_result.threat_name 값이 직접 복사됨
emshostname, remotename target.hostname 비어 있지 않으면 emshostname의 값, 그렇지 않으면 remotename
dstip target.ip dstip에서 유효한 IP 추출
dstport target.port 정수로 변환되며, 0이 아닌 경우 값이 복사됩니다.
metadata.product_name 'FORTINET_FORTICLIENT'로 설정
metadata.vendor_name 'FORTINET_FORTICLIENT'로 설정

도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가에게 문의하여 답변을 받으세요.