BeyondTrust Privileged Identity 로그 수집
이 문서에서는 Bindplane을 사용하여 BeyondTrust Privileged Identity 로그를 Google Security Operations에 수집하는 방법을 설명합니다. 파서는 BeyondTrust Remote Support 로그를 추출하여 CEF 및 비 CEF 형식 syslog 메시지를 모두 처리합니다. 키 필드를 파싱하고, 통합 데이터 모델 (UDM)에 매핑하고, dst
, src
, suid
, sEventID
와 같은 추출된 필드를 기반으로 이벤트 유형을 결정하여 사용자 세부정보, IP 주소, 보안 결과와 같은 추가 컨텍스트로 데이터를 보강합니다.
시작하기 전에
다음 기본 요건이 충족되었는지 확인합니다.
- Google SecOps 인스턴스
- Windows 2016 이상 또는
systemd
가 설치된 Linux 호스트 - 프록시 뒤에서 실행하는 경우 방화벽 포트가 열려 있음
- BeyondTrust Privileged Remote Access Appliance에 대한 액세스 권한
Google SecOps 수집 인증 파일 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 수집 에이전트로 이동합니다.
- 수집 인증 파일을 다운로드합니다. Bindplane이 설치될 시스템에 파일을 안전하게 저장합니다.
Google SecOps 고객 ID 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 프로필로 이동합니다.
- 조직 세부정보 섹션에서 고객 ID를 복사하여 저장합니다.
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: '/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 ingestion_labels: log_type: 'BEYONDTRUST_PI' raw_log_field: body 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
BeyondTrust Privileged Identity에서 Syslog 구성
- Beyondtrust Privileged Appliance에 로그인합니다.
- 어플라이언스 > 보안 > 어플라이언스 관리로 이동합니다.
- Syslog 섹션으로 이동합니다.
- 다음 구성 세부정보를 제공합니다.
- 호스트 이름: Bindplane 에이전트 IP 주소를 입력합니다.
- 포트: 기본 포트는 514 (UDP)로 설정됩니다.
- 형식: RFC 5424를 선택합니다.
- 저장을 클릭합니다.
UDM 매핑 테이블
로그 필드 | UDM 매핑 | 논리 |
---|---|---|
cs1 | additional.fields[0].key | 원시 로그 필드 cs1Label 에서 직접 매핑됩니다. |
cs1Label | additional.fields[0].value.string_value | 원시 로그 필드 cs1 에서 직접 매핑됩니다. |
cs3 | additional.fields[1].value.string_value | 원시 로그 필드 cs3Label 에서 직접 매핑됩니다. |
cs3Label | additional.fields[1].key | 원시 로그 필드 cs3 에서 직접 매핑됩니다. |
cs4 | additional.fields[2].value.string_value | 원시 로그 필드 cs4Label 에서 직접 매핑됩니다. |
cs4Label | additional.fields[2].key | 원시 로그 필드 cs4 에서 직접 매핑됩니다. |
데이터 | metadata.description | CEF 메시지의 경우 msg 필드 (data 에서 추출됨)가 metadata.description 에 매핑됩니다. CEF가 아닌 메시지의 경우 sMessage 필드 (또는 특정 메시지 형식에 따라 일부)가 metadata.description 에 매핑됩니다. |
dhost | target.hostname | 원시 로그 필드 dhost 에서 직접 매핑됩니다. |
dntdom | target.administrative_domain | 원시 로그 필드 dntdom 에서 직접 매핑됩니다. |
duser | target.user.user_display_name | 원시 로그 필드 duser 에서 직접 매핑됩니다. |
msg | metadata.description | CEF 메시지의 원시 로그 필드 msg 에서 직접 매핑됩니다. |
rt | metadata.event_timestamp.seconds | 에포크 타임스탬프는 CEF 메시지의 rt 필드에서 추출됩니다. |
sEventType | metadata.product_event_type | CEF가 아닌 메시지의 원시 로그 필드 sEventType 에서 직접 매핑됩니다. |
shost | principal.ip | 원시 로그 필드 shost 에서 직접 매핑됩니다. |
sIpAddress | principal.ip | CEF가 아닌 메시지의 원시 로그 필드 sIpAddress 에서 직접 매핑됩니다. |
sLoginName | principal.user.userid | 도메인과 사용자 ID를 구분하기 위해 정규 표현식을 사용하여 sLoginName 필드에서 추출됩니다. |
sMessage | security_result.description | CEF가 아닌 메시지의 원시 로그 필드 sMessage 에서 직접 매핑되거나 추출된 부분이 security_result.description 에 사용됩니다. |
sntdom | principal.administrative_domain | 원시 로그 필드 sntdom 에서 직접 매핑됩니다. |
sOriginatingAccount | principal.user.userid | 도메인과 사용자 ID를 구분하기 위해 정규 표현식을 사용하여 sOriginatingAccount 필드에서 추출됩니다. |
sOriginatingApplicationComponent | principal.application | sOriginatingApplicationName 와 함께 사용하여 principal.application 를 채웁니다. |
sOriginatingApplicationName | principal.application | sOriginatingApplicationComponent 와 함께 사용하여 principal.application 를 채웁니다. |
sOriginatingSystem | principal.hostname | CEF가 아닌 메시지의 원시 로그 필드 sOriginatingSystem 에서 직접 매핑됩니다. |
suser | principal.user.user_display_name | 원시 로그 필드 suser 에서 직접 매핑됩니다. dst , src , shost , suid 와 같은 다른 필드의 존재 및 값에 따라 파서 논리에 의해 결정됩니다. 가능한 값은 NETWORK_CONNECTION , STATUS_UPDATE , USER_UNCATEGORIZED , GENERIC_EVENT 입니다. 'BEYONDTRUST_PI'로 설정합니다. 'BeyondTrust Remote Support'로 설정합니다. CEF 메시지의 CEF 헤더에서 추출됩니다. 'BeyondTrust'로 설정합니다. status , reason 또는 sMessage 필드에 따라 'ALLOW' 또는 'BLOCK'으로 설정됩니다. LOW 로 설정합니다. |
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가로부터 답변을 받으세요.