Forcepoint NGFW 로그 수집
이 문서에서는 Bindplane을 사용하여 Forcepoint NGFW 로그를 Google Security Operations에 수집하는 방법을 설명합니다. 파서는 JSON 로그 또는 CEF 형식 메시지에서 필드를 추출하고, 이를 통합 데이터 모델 (UDM)로 정규화하고, 공급업체 및 제품 메타데이터로 데이터를 보강합니다. 그로크 패턴과 조건부 로직을 사용하여 원시 로그 필드를 네트워크 연결 세부정보, 보안 결과, 메타데이터를 비롯한 UDM 필드에 매핑하여 JSON 및 CEF 형식 로그를 모두 처리합니다.
시작하기 전에
다음 기본 요건이 충족되었는지 확인합니다.
- Google SecOps 인스턴스
systemd이 설치된 Windows 2016 이상 또는 Linux 호스트- 프록시 뒤에서 실행하는 경우 Bindplane 에이전트 요구사항에 따라 방화벽 포트가 열려 있는지 확인합니다.
- Forcepoint Security Management Center (SMC)에 대한 권한 있는 액세스
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
Linux 설치
- 루트 또는 sudo 권한으로 터미널을 엽니다.
다음 명령어를 실행합니다.
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
추가 설치 리소스
- 추가 설치 옵션은 이 설치 가이드를 참고하세요.
Syslog를 수집하여 Google SecOps로 전송하도록 Bindplane 에이전트 구성
구성 파일에 액세스합니다.
config.yaml파일을 찾습니다. 일반적으로 Linux에서는/etc/bindplane-agent/디렉터리에 있고 Windows에서는 설치 디렉터리에 있습니다.- 텍스트 편집기 (예:
nano,vi, 메모장)를 사용하여 파일을 엽니다.
다음과 같이
config.yaml파일을 수정합니다.receivers: tcplog: # Replace the port and IP address as required listen_address: "0.0.0.0:514" exporters: chronicle/chronicle_w_labels: compression: gzip # Adjust the path to the credentials file you downloaded in Step 1 creds_file_path: '/path/to/ingestion-authentication-file.json' # Replace with your actual customer ID from Step 2 customer_id: YOUR_CUSTOMER_ID endpoint: malachiteingestion-pa.googleapis.com # Add optional ingestion labels for better organization log_type: 'FORCEPOINT_FIREWALL' raw_log_field: body ingestion_labels: service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - tcplog exporters: - chronicle/chronicle_w_labels- 인프라에 필요한 대로 포트와 IP 주소를 바꿉니다.
<CUSTOMER_ID>를 실제 고객 ID로 바꿉니다.- Google SecOps 수집 인증 파일 가져오기 섹션에서 인증 파일이 저장된 경로로
/path/to/ingestion-authentication-file.json를 업데이트합니다.
Bindplane 에이전트를 다시 시작하여 변경사항 적용
Linux에서 Bindplane 에이전트를 다시 시작하려면 다음 명령어를 실행합니다.
sudo systemctl restart bindplane-agentWindows에서 Bindplane 에이전트를 다시 시작하려면 서비스 콘솔을 사용하거나 다음 명령어를 입력하면 됩니다.
net stop BindPlaneAgent && net start BindPlaneAgent
Forcepoint NGFW에서 Syslog 전달 구성
- Forcepoint Security Management Center (SMC)에 로그인합니다.
- 구성 > 로그 서버 > 속성으로 이동합니다.
- 로그 전달 섹션으로 이동합니다.
- 추가를 클릭하여 새 전달 규칙을 만듭니다.
- 다음 구성 세부정보를 제공합니다.
- 이름: 설명이 포함된 이름을 입력합니다 (예:
Google SecOps BindPlane Syslog). - 호스트: Bindplane 에이전트 IP 주소를 입력합니다.
- 포트: Bindplane 에이전트 포트 번호를 입력합니다 (예:
514). - 프로토콜: 실제 Bindplane 에이전트 구성에 따라 TCP 또는 UDP를 선택합니다.
- 형식: JSON을 선택합니다.
- 이름: 설명이 포함된 이름을 입력합니다 (예:
- 전달할 로그 필드를 구성합니다.
- 필드 선택을 클릭하거나 필드 선택 구성에 액세스합니다.
- 요구사항에 따라 관련 로그 필드를 선택합니다. 다음 필드는 일반적으로 보안 분석에 필요합니다.
TIMESTAMP(생성 시간)LOG_ID(데이터 식별자)EVENT(이벤트)EVENT_ID(이벤트 ID)SRC(소스 주소)DST(대상 주소)Sport(소스 포트)Dport(대상 포트)PROTOCOL(프로토콜)SERVICE(서비스)RULE_ID(규칙 태그)ACTION(작업)NAT_SRC,NAT_DST,NAT_SPORT,NAT_DPORT(NAT 필드)ACC_RX_BYTES,ACC_TX_BYTES,ACC_ELAPSED(회계 필드)NODE_ID(발신자)COMP_ID(구성요소 ID)FACILITY(시설)INFO_MSG(정보 메시지)SITUATION(상황)APPLICATION(애플리케이션)
- 내보낼 수 있는 필드의 전체 목록은 Forcepoint NGFW 내보낼 수 있는 방화벽 및 레이어 2 방화벽 로그 항목 필드 문서를 참고하세요.
- 이벤트 섹션으로 이동하여 모두를 선택합니다.
- 구성을 저장합니다.
- 로그 서버에 변경사항을 적용합니다.
UDM 매핑 테이블
| 로그 필드 | UDM 매핑 | 논리 |
|---|---|---|
AccElapsed |
network.session_duration.seconds |
비어 있지 않거나 0이 아닌 경우 AccElapsed에서 직접 매핑됩니다. 정수로 변환되었습니다. |
AccRxBytes |
network.received_bytes |
AccRxBytes에서 직접 매핑됩니다. 부호 없는 정수로 변환되었습니다. |
AccTxBytes |
network.sent_bytes |
AccTxBytes에서 직접 매핑됩니다. 부호 없는 정수로 변환되었습니다. |
Action |
security_result.action_details |
Action에서 직접 매핑됩니다. |
Action |
security_result.action |
Action이 '허용'인 경우 'ALLOW'로 설정합니다. Action가 'Discard'인 경우 'BLOCK'으로 설정합니다. |
CompId |
target.hostname |
CompId에서 직접 매핑됩니다. |
Dport |
target.port |
0이 아닌 경우 Dport에서 직접 매핑됩니다. 정수로 변환되었습니다. |
Dst |
target.ip |
Dst에서 직접 매핑됩니다. |
Event |
metadata.product_event_type |
Event에서 직접 매핑됩니다. |
Facility |
metadata.description |
Facility에서 직접 매핑됩니다. |
InfoMsg |
security_result.description |
InfoMsg에서 직접 매핑됩니다. |
LogId |
metadata.product_log_id |
LogId에서 직접 매핑됩니다. |
NatDport |
target.nat_port |
0이 아닌 경우 NatDport에서 직접 매핑됩니다. 정수로 변환되었습니다. |
NatDst |
target.nat_ip |
NatDst에서 직접 매핑됩니다. |
NatSport |
principal.nat_port |
0이 아닌 경우 NatSport에서 직접 매핑됩니다. 정수로 변환되었습니다. |
NatSrc |
principal.nat_ip |
NatSrc에서 직접 매핑됩니다. |
NodeId |
intermediary.ip |
Src 또는 Dst와 NodeId가 모두 있는 경우 NodeId에서 직접 매핑됩니다. |
NodeId |
principal.ip |
NodeId이 있지만 Src 및 Dst가 없는 경우 NodeId에서 직접 매핑됩니다. |
Protocol |
network.ip_protocol |
정수로 변환한 후 조회를 사용하여 숫자를 프로토콜 이름으로 변환한 후 Protocol에서 매핑됩니다 (예: 6이 TCP가 됩니다. |
RuleId |
security_result.rule_id |
RuleId에서 직접 매핑됩니다. |
Service |
principal.application |
'Dest.Service 연결할 수 없음 (포트 연결할 수 없음)' |
Service |
network.application_protocol |
Service이 'HTTP' 또는 'HTTPS'인 경우 Service 값으로 설정합니다. Service에 'DNS'가 포함된 경우 'DNS'로 설정합니다. |
Service |
metadata.event_type |
Service이 'HTTP' 또는 'HTTPS'인 경우 metadata.event_type을 'NETWORK_HTTP'로 설정합니다. |
Situation |
security_result.summary |
Situation에서 직접 매핑됩니다. |
Sport |
principal.port |
0이 아닌 경우 Sport에서 직접 매핑됩니다. 정수로 변환되었습니다. |
Src |
principal.ip |
Src에서 직접 매핑됩니다. |
Timestamp |
metadata.event_timestamp |
날짜로 파싱한 후 Timestamp에서 직접 매핑됩니다. |
Type |
security_result.severity_details |
Type에서 직접 매핑됩니다. |
Type |
security_result.severity |
Type가 '알림'인 경우 'LOW'로 설정합니다. Src 또는 NodeId과 Dst 또는 CompId이 있는 경우 'NETWORK_CONNECTION'으로 설정합니다. principal.ip만 있는 경우 'STATUS_UPDATE'로 설정됩니다. 그 외의 경우에는 'GENERIC_EVENT'로 설정합니다. 'FORCEPOINT_FIREWALL'로 설정합니다. 'FORCEPOINT FIREWALL'로 설정합니다. 'FORCEPOINT'로 설정합니다. |
rt |
metadata.event_timestamp |
CEF 블록에서 날짜로 파싱한 후 rt에서 직접 매핑됩니다. |
act |
security_result.action_details |
CEF 블록의 act에서 직접 매핑됩니다. |
app |
principal.application |
CEF 블록의 app에서 직접 매핑됩니다. |
deviceFacility |
metadata.description |
CEF 블록의 deviceFacility에서 직접 매핑됩니다. |
destinationTranslatedAddress |
target.nat_ip |
CEF 블록의 destinationTranslatedAddress에서 직접 매핑됩니다. |
destinationTranslatedPort |
target.nat_port |
CEF 블록의 destinationTranslatedPort에서 직접 매핑됩니다. |
dst |
target.ip |
CEF 블록의 dst에서 직접 매핑됩니다. |
dpt |
target.port |
CEF 블록의 dpt에서 직접 매핑됩니다. |
dvchost |
intermediary.ip |
CEF 블록의 dvchost에서 직접 매핑됩니다. |
event_name |
metadata.product_event_type |
CEF 블록의 event_name에서 직접 매핑됩니다. |
msg |
security_result.description |
CEF 블록의 msg에서 직접 매핑됩니다. |
proto |
network.ip_protocol |
정수로 변환한 후 조회를 사용하여 숫자를 프로토콜 이름으로 변환한 후 proto에서 매핑됩니다 (예: 6이 TCP로 바뀝니다. |
sourceTranslatedAddress |
principal.nat_ip |
CEF 블록의 sourceTranslatedAddress에서 직접 매핑됩니다. |
sourceTranslatedPort |
principal.nat_port |
CEF 블록의 sourceTranslatedPort에서 직접 매핑됩니다. |
spt |
principal.port |
CEF 블록의 spt에서 직접 매핑됩니다. |
src |
principal.ip |
CEF 블록의 src에서 직접 매핑됩니다. |
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가에게 문의하여 답변을 받으세요.