Veeam 로그 수집
이 문서에서는 Bindplane을 사용하여 Veeam 로그를 Google Security Operations에 수집하는 방법을 설명합니다. 파서는 grok 패턴을 사용하여 syslog 메시지에서 필드를 추출하고, 필드 바꾸기 및 병합과 같은 데이터 변환을 실행하고, 이벤트 유형 및 사용 가능한 필드에 따라 추출된 데이터를 통합 데이터 모델 (UDM)에 매핑합니다. 또한 오류 조건을 처리하고 적절한 심각도 수준을 설정합니다.
시작하기 전에
다음 기본 요건이 충족되었는지 확인합니다.
- Google SecOps 인스턴스
- Windows 2016 이상 또는
systemd
가 설치된 Linux 호스트 - 프록시 뒤에서 실행하는 경우 방화벽 포트가 열려 있는지 확인
- Veeam에 대한 액세스 권한 관리
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: udplog: # 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: <customer_id> endpoint: malachiteingestion-pa.googleapis.com # Add optional ingestion labels for better organization log_type: 'VEEAM' raw_log_field: body ingestion_labels: service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels
- 인프라에 필요한 대로 포트와 IP 주소를 바꿉니다.
<customer_id>
를 실제 고객 ID로 바꿉니다.- Google SecOps 수집 인증 파일 가져오기 섹션에서 인증 파일이 저장된 경로로
/path/to/ingestion-authentication-file.json
를 업데이트합니다.
Bindplane 에이전트를 다시 시작하여 변경사항 적용
Linux에서 Bindplane 에이전트를 다시 시작하려면 다음 명령어를 실행합니다.
sudo systemctl restart bindplane-agent
Windows에서 Bindplane 에이전트를 다시 시작하려면 서비스 콘솔을 사용하거나 다음 명령어를 입력하면 됩니다.
net stop BindPlaneAgent && net start BindPlaneAgent
Veeam용 Syslog 구성
- Veeam Backup & Replication 콘솔에 로그인합니다.
- 메뉴 > 옵션 > SIEM 통합으로 이동합니다.
- Syslog servers 섹션에서 Add를 클릭합니다.
- 다음 구성 세부정보를 제공합니다.
- 이름: Bindplane 에이전트 IP 주소와 포트 번호를 입력합니다 (예:
192.168.1.1:514
). - 전송: 실제 Bindplane 에이전트 구성에 따라 UDP 또는 TCP를 선택합니다.
- 이름: Bindplane 에이전트 IP 주소와 포트 번호를 입력합니다 (예:
- 확인을 클릭하여 저장합니다.
UDM 매핑 테이블
로그 필드 | UDM 매핑 | 논리 |
---|---|---|
application |
principal.application |
grok 패턴으로 추출된 application 필드에서 직접 매핑됩니다. |
CredentialId |
principal.resource.attribute.labels.[] |
kv 필터로 추출된 CredentialId 필드에서 직접 매핑됩니다. 키가 'CredentialId'인 라벨이 생성됩니다. |
date_2 , time_2 , year |
metadata.event_timestamp |
date_2 , time_2 , year 필드는 date 필터를 사용하여 연결되고 파싱되어 metadata.event_timestamp 을 만듭니다. |
date_2 , time_2 |
metadata.event_timestamp |
date_2 및 time_2 필드는 date 필터를 사용하여 연결되고 파싱되어 metadata.event_timestamp 를 만듭니다. |
deviceId |
principal.resource.product_object_id |
kv 필터로 추출된 deviceId 필드에서 직접 매핑됩니다. |
description |
security_result.description |
grok 패턴으로 추출된 description 필드에서 직접 매핑됩니다. |
error_code |
security_result.detection_fields.[] |
grok 패턴으로 추출된 error_code 필드에서 직접 매핑됩니다. 키가 'error_code'인 라벨이 생성됩니다. |
executing_feature |
principal.hostname , principal.asset.hostname |
grok 패턴으로 추출된 executing_feature 필드에서 직접 매핑됩니다. |
host |
principal.hostname , principal.asset.hostname |
grok 패턴으로 추출된 host 필드에서 직접 매핑됩니다. |
ManagementIP |
principal.ip , principal.asset.ip |
kv 필터로 추출된 ManagementIP 필드에서 직접 매핑됩니다. |
pid |
principal.process.pid |
grok 패턴으로 추출된 pid 필드에서 직접 매핑됩니다. |
previousSeverity |
security_result.severity_details |
grok 패턴으로 추출된 previousSeverity 필드에서 직접 매핑됩니다. |
prod_event_type |
metadata.product_event_type |
grok 패턴으로 추출된 prod_event_type 필드에서 직접 매핑됩니다. |
query |
security_result.detection_fields.[] |
grok 패턴으로 추출된 query 필드에서 직접 매핑됩니다. 키가 'query'인 라벨이 생성됩니다. |
reportingAddress |
principal.ip , principal.asset.ip |
grok 패턴으로 추출된 reportingAddress 필드에서 직접 매핑됩니다. |
severity |
security_result.severity |
severity 필드에서 매핑되었습니다. 값은 severity 필드를 기반으로 하는 조건부 논리에 따라 결정됩니다 (ERROR, MAJOR/WARN, INFO는 특정 UDM 심각도 값에 매핑됨). |
src_ip |
principal.ip , principal.asset.ip |
grok 패턴으로 추출된 src_ip 필드에서 직접 매핑됩니다. |
summary |
security_result.summary |
grok 패턴으로 추출된 summary 필드에서 직접 매핑됩니다. |
target_ip |
target.ip , target.asset.ip |
grok 패턴으로 추출된 target_ip 필드에서 직접 매핑됩니다. |
thread_id |
security_result.detection_fields.[] |
grok 패턴으로 추출된 thread_id 필드에서 직접 매핑됩니다. 키가 'thread_id'인 라벨이 생성됩니다. |
(해당 사항 없음) | event_type |
파서의 논리에 따라 결정됩니다. principal 와 target 에 모두 MID 데이터가 있으면 NETWORK_UNCATEGORIZED 입니다. principal 에만 MID 데이터가 있는 경우 STATUS_UPDATE 입니다. 그렇지 않은 경우 GENERIC_EVENT 입니다. |
(해당 사항 없음) | metadata.event_type |
내부적으로 생성된 event_type 필드에서 복사되었습니다. |
(해당 사항 없음) | metadata.vendor_name |
'VEEAM'으로 하드코딩됨 |
(해당 사항 없음) | metadata.product_name |
'Veeam'으로 하드코딩됩니다. |
(해당 사항 없음) | event.timestamp |
이벤트 타임스탬프는 로그 항목의 collection_time 필드에서 가져옵니다. |
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가로부터 답변을 받으세요.