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 수집 인증 파일 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 수집 에이전트로 이동합니다.
- 다운로드를 클릭하여 수집 인증 파일을 다운로드합니다.
Bindplane 에이전트가 설치될 시스템에 파일을 안전하게 저장합니다.
Google SecOps 고객 ID 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 프로필로 이동합니다.
조직 세부정보 섹션에서 고객 ID를 복사하여 저장합니다.
Bindplane 에이전트 설치
다음 안내에 따라 Windows 또는 Linux 운영체제에 Bindplane 에이전트를 설치합니다.
Windows 설치
- 명령 프롬프트 또는 PowerShell을 관리자로 엽니다.
다음 명령어를 실행합니다.
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet설치가 완료될 때까지 기다립니다.
다음을 실행하여 설치를 확인합니다.
sc query observiq-otel-collector
서비스가 실행 중으로 표시되어야 합니다.
Linux 설치
- 루트 또는 sudo 권한으로 터미널을 엽니다.
다음 명령어를 실행합니다.
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh설치가 완료될 때까지 기다립니다.
다음을 실행하여 설치를 확인합니다.
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
- Linux:
customer_id: Google SecOps 콘솔의 고객 IDendpoint: 리전 엔드포인트 URL:- 미국:
malachiteingestion-pa.googleapis.com - 유럽:
europe-malachiteingestion-pa.googleapis.com - 아시아:
asia-southeast1-malachiteingestion-pa.googleapis.com - 전체 목록은 리전 엔드포인트를 참고하세요.
- 미국:
log_type:FORTINET_FORTICLIENTingestion_labels: YAML 형식의 선택적 라벨
구성 파일 저장
수정 후 파일을 저장합니다.
- Linux:
Ctrl+O,Enter,Ctrl+X순으로 누릅니다. - Windows: 파일 > 저장을 클릭합니다.
변경사항을 적용하려면 Bindplane 에이전트를 다시 시작하세요.
Linux
sudo systemctl restart observiq-otel-collector서비스가 실행 중인지 확인합니다.
sudo systemctl status observiq-otel-collector로그에서 오류를 확인합니다.
sudo journalctl -u observiq-otel-collector -f
Windows
다음 옵션 중 하나를 선택합니다.
명령 프롬프트 또는 PowerShell을 관리자로 사용합니다.
net stop observiq-otel-collector && net start observiq-otel-collector서비스 콘솔 사용:
Win+R를 누르고services.msc를 입력한 다음 Enter 키를 누릅니다.- observIQ OpenTelemetry Collector를 찾습니다.
마우스 오른쪽 버튼을 클릭하고 다시 시작을 선택합니다.
서비스가 실행 중인지 확인합니다.
sc query observiq-otel-collector로그에서 오류를 확인합니다.
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
로그를 Bindplane 에이전트로 보내도록 FortiClient 엔드포인트 로깅 구성
FortiClient 엔드포인트 로깅은 XML 구성으로 엔드포인트 프로필을 수정하여 FortiClient EMS를 통해 중앙에서 구성됩니다. EMS는 로깅 구성을 FortiClient 엔드포인트로 푸시하고, 엔드포인트는 로그를 Bindplane 에이전트 syslog 리스너로 직접 전송합니다.
FortiClient EMS에 로그인
- FortiClient EMS 웹 콘솔에 로그인합니다.
- 엔드포인트 프로필 > 프로필 관리로 이동합니다.
엔드포인트 프로필 수정 또는 만들기
- 기존 프로필을 선택하여 수정하거나 추가를 클릭하여 새 프로필을 만듭니다.
- 프로필 이름 필드에 설명이 포함된 이름을 입력합니다 (예:
Chronicle-Logging-Profile). - 고급을 클릭합니다.
- XML 구성 탭을 클릭합니다.
- 수정을 클릭합니다.
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= Emergency1= Alert2= 심각3= 오류4= 경고5= 알림6= 정보 (권장)7= 디버그
<log_events>: 로깅할 FortiClient 이벤트 또는 프로세스를 쉼표로 구분한 목록입니다. 캡처하려는 이벤트 (예:ipsecvpn,sslvpn,firewall,av,webfilter,endpoint)를 포함합니다.
프로필 저장
- XML 테스트를 클릭하여 XML 구성의 유효성을 검사합니다.
- 저장을 클릭하여 프로필을 저장합니다.
엔드포인트에 프로필 적용
- 엔드포인트 정책 > 정책 관리로 이동합니다.
- 기존 정책을 선택하거나 추가를 클릭하여 새 정책을 만듭니다.
- 프로필 드롭다운에서 생성하거나 수정한 프로필을 선택합니다.
- 엔드포인트 그룹 섹션에서 정책을 적용할 엔드포인트 그룹을 선택합니다.
- 저장을 클릭합니다.
EMS는 다음 원격 분석 통신을 통해 프로필 구성을 엔드포인트로 푸시합니다. FortiClient 엔드포인트가 Bindplane 에이전트 syslog 리스너에 로그를 전송하기 시작합니다.
로그 전달 확인
Bindplane 에이전트 호스트에서 에이전트 로그를 확인하여 로그가 수신되고 있는지 확인합니다.
Linux:
sudo journalctl -u observiq-otel-collector -fWindows:
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"FortiClient 엔드포인트에서 FortiClient 로그를 확인하여 원격 로깅이 사용 설정되어 있는지 확인합니다.
Windows:
C:\Program Files\Fortinet\FortiClient\logs\macOS:
/Library/Application Support/Fortinet/FortiClient/logs/Linux:
/var/log/forticlient/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 전문가에게 문의하여 답변을 받으세요.