HPE BladeSystem c7000 로그 수집
이 문서에서는 Bindplane을 사용하여 HPE BladeSystem C7000 로그를 Google Security Operations에 수집하는 방법을 설명합니다. 파서 코드는 정규식을 사용하여 HPE BladeSystem c7000 syslog 메시지에서 필드를 추출한 다음 심각도 수준 및 설명 라벨과 같은 추가 컨텍스트로 데이터를 보강하면서 이러한 필드를 통합 데이터 모델 (UDM)에 매핑합니다. 다양한 로그 메시지 구조를 처리하여 보안 모니터링 및 분석을 위한 일관된 표현을 제공합니다.
시작하기 전에
다음 기본 요건이 충족되었는지 확인합니다.
- Google SecOps 인스턴스
- Windows 2016 이상 또는
systemd
가 설치된 Linux 호스트 - 프록시 뒤에서 실행하는 경우 방화벽 포트가 열려 있음
- HPE Grid Manager에 대한 권한이 있는 액세스
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: 'HPE_BLADESYSTEM_C7000' 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
HPE BladeSystem에서 직접 Syslog 구성
- BladeSystem UI에 로그인합니다.
- 구성 > 시스템 로그로 이동합니다.
- 로그 옵션 탭을 클릭합니다.
- 원격 시스템 로깅 사용 설정 체크박스를 선택합니다.
- 다음 구성 세부정보를 제공합니다.
- Syslog Server Address(Syslog 서버 주소): Bindplane 에이전트 IP 주소를 입력합니다.
- 포트: Bindplane 에이전트 포트 번호를 입력합니다 (기본 포트는
514
). - 프로토콜: 프로토콜은 항상 UDP입니다.
- 원격 로그 테스트를 클릭하고 로그가 수신되는지 확인합니다.
- 적용을 클릭하여 저장합니다.
StorageGRID 소프트웨어에서 Syslog 구성
StorageGRID 내에서 감사 메시지 수준을 구성하고 이러한 메시지를 전달하기 위해 외부 Syslog 서버를 설정할 수 있습니다.
StorageGRID 감사 메시지 수준 구성
- GRID Manage 웹 UI에 로그인합니다.
- 구성 > 모니터링 > 감사 및 syslog 서버로 이동합니다.
- 감사 메시지의 각 카테고리에 대해 목록에서 일반 감사 수준을 선택합니다.
- 저장을 클릭합니다.
StorageGRID 외부 Syslog 서버 구성
- 감사 및 시스템로그 서버 페이지에서 외부 시스템로그 서버 구성을 클릭합니다.
- 다음 구성 세부정보를 제공합니다.
- syslog 정보를 입력합니다. Bindplane 에이전트 IP 주소를 입력합니다.
- Bindplane 에이전트 포트 번호를 입력합니다 (기본 포트는
514
). - Bindplane 에이전트 구성에 따라 UDP 또는 TCP 프로토콜을 선택합니다.
- 계속을 클릭합니다.
Syslog 이벤트 구성
- 마법사의 syslog 콘텐츠 관리 단계에서 외부 syslog 서버로 전송할 각 감사 정보 유형을 선택합니다.
- 감사 로그 보내기
- 보안 이벤트 전송
- 애플리케이션 로그 보내기
- 액세스 로그 보내기
- 심각도에서 패스 스루 또는 7 (정보)을 선택합니다.
- 기능에서 패스 스루를 선택합니다.
- 계속을 클릭합니다.
UDM 매핑 테이블
로그 필드 | UDM 매핑 | 논리 |
---|---|---|
명령어 | principal.process.command_line | 원시 로그 필드 'command'에서 직접 매핑됩니다. |
구성요소 | metadata.product_event_type | 원시 로그 필드 '구성요소'에서 직접 매핑됩니다. |
component_name | additional.fields[0].value.string_value | 원시 로그 필드 'component_name'에서 직접 매핑됩니다. |
description | security_result.description | 선택적 grok 파싱 후 원시 로그 필드 'description'에서 직접 매핑됩니다. |
description | security_result.detection_fields[0].value | grok 패턴을 사용하여 'description' 필드에서 추출됩니다. 현재 상태를 나타냅니다. |
description | security_result.detection_fields[1].value | grok 패턴을 사용하여 'description' 필드에서 추출됩니다. 이전 상태를 나타냅니다. |
description | security_result.detection_fields[2].value | grok 패턴을 사용하여 'description' 필드에서 추출됩니다. 상태 변경의 원인을 나타냅니다. |
event_timestamp | metadata.event_timestamp | 날짜 파싱 후 원시 로그 필드 'event_timestamp'에서 직접 매핑됩니다. |
호스트 이름 | principal.hostname | 원시 로그 필드 'hostname'에서 직접 매핑됩니다. |
호스트 이름 | principal.asset.hostname | 매핑된 'principal.hostname' 필드에서 복사됩니다. |
internal_code | additional.fields[1].value.string_value | 원시 로그 필드 'internal_code'에서 직접 매핑됩니다. |
priority_id | additional.fields[2].value.string_value | 원시 로그 필드 'priority_id'에서 직접 매핑됩니다. |
additional.fields[0].key | 정적 값: '구성요소 이름' | |
additional.fields[1].key | 정적 값: 'Internal Code' | |
additional.fields[2].key | 정적 값: 'Priority Id' | |
metadata.event_type | 'principal.hostname'이 성공적으로 추출되면 'STATUS_UPDATE'로 설정되고, 그렇지 않으면 'GENERIC_EVENT'로 설정됩니다. | |
metadata.vendor_name | 정적 값: 'HP' | |
metadata.product_name | 정적 값: 'HPE BladeSystem c7000' | |
metadata.log_type | 정적 값: 'HPE_BLADESYSTEM_C7000' | |
security_result.severity | 다음 로직에 따라 'severity' 필드에서 매핑됩니다. - 'Critical' -> 'CRITICAL' - 'Major' -> 'HIGH' - 'Warning' -> 'MEDIUM' - 'Info', 'Minor' -> 'LOW' - Default -> 'UNKNOWN_SEVERITY' |
|
security_result.detection_fields[0].key | 정적 값: '현재 상태' | |
security_result.detection_fields[1].key | 정적 값: '이전 상태' | |
security_result.detection_fields[2].key | 정적 값: '원인' |
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가로부터 답변을 받으세요.