Microsoft PowerShell 로그 수집

다음에서 지원:

이 문서에서는 Bindplane 에이전트를 사용하여 Microsoft PowerShell 로그를 Google Security Operations로 수집하는 방법을 설명합니다.

Microsoft PowerShell은 명령줄 셸과 스크립트 언어로 구성된 Microsoft의 작업 자동화 및 구성 관리 프레임워크입니다. PowerShell 로그는 스크립트 실행, 모듈 활동, 명령어 호출을 캡처하여 보안 모니터링 및 포렌식 분석을 위한 PowerShell 작업에 대한 가시성을 제공합니다.

시작하기 전에

다음 기본 요건이 충족되었는지 확인합니다.

  • Google SecOps 인스턴스
  • Windows Server 2016 이상
  • Windows 호스트와 Google SecOps 간의 네트워크 연결
  • 프록시 뒤에서 실행하는 경우 Bindplane 에이전트 요구사항에 따라 방화벽 포트가 열려 있는지 확인합니다.
  • PowerShell 로깅을 구성하고 Bindplane 에이전트를 설치하기 위한 Windows 호스트에 대한 관리 액세스 권한

PowerShell 로깅 구성

로그를 수집하려면 먼저 Windows 호스트에서 PowerShell 로깅을 사용 설정해야 합니다. 기본적으로 PowerShell 로깅은 최소화됩니다. 스크립트 블록 로깅을 사용 설정하여 자세한 PowerShell 활동을 캡처합니다.

그룹 정책을 사용하여 스크립트 차단 로깅 사용 설정

  1. 관리자로 gpedit.msc를 실행하여 로컬 그룹 정책 편집기를 엽니다.
  2. Computer Configuration(컴퓨터 구성) > Administrative Templates(관리 템플릿) > Windows Components(Windows 구성요소) > Windows PowerShell로 이동합니다.
  3. PowerShell 스크립트 블록 로깅 사용 설정을 더블클릭합니다.
  4. Enabled(사용 설정됨)를 선택합니다.
  5. 선택적으로 스크립트 블록 호출 시작 / 중지 이벤트 로깅을 선택하여 각 스크립트 블록의 시작 및 중지 이벤트를 캡처합니다. 이 옵션은 많은 양의 로그를 생성합니다.
  6. 확인을 클릭합니다.
  7. 관리자 권한으로 명령 프롬프트를 열고 gpupdate /force를 실행하여 정책을 즉시 적용합니다.

레지스트리를 사용하여 스크립트 차단 로깅 사용 설정

또는 다음 레지스트리 값을 설정하여 스크립트 차단 로깅을 사용 설정할 수 있습니다.

  1. 관리자 권한으로 regedit를 실행하여 레지스트리 편집기를 엽니다.
  2. HKLM\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging로 이동합니다.
  3. 키가 없으면 키를 만듭니다.
  4. EnableScriptBlockLogging라는 새 DWORD (32비트) 값을 만들고 값을 1으로 설정합니다.
  5. 변경사항이 적용되도록 PowerShell 세션을 다시 시작합니다.

PowerShell 스크립트 블록 로깅은 이벤트 ID 4104를 사용하여 Microsoft-Windows-PowerShell/Operational 이벤트 로그 채널에 이벤트를 작성합니다.

선택사항: 모듈 로깅 사용 설정

모듈 로깅은 지정된 모듈의 파이프라인 실행 세부정보를 기록합니다. 모든 모듈에 대해 모듈 로깅을 사용 설정하려면 다음을 실행하세요.

  1. 로컬 그룹 정책 편집기에서 컴퓨터 구성 > 관리 템플릿 > Windows 구성요소 > Windows PowerShell로 이동합니다.
  2. 모듈 로깅 사용 설정을 더블클릭합니다.
  3. Enabled(사용 설정됨)를 선택합니다.
  4. 모듈 이름 옆에 있는 표시를 클릭합니다.
  5. *을 입력하여 모든 모듈을 로깅합니다.
  6. Module Names 창에서 OK를 클릭합니다.
  7. 모듈 로깅 창에서 확인을 클릭합니다.
  8. gpupdate /force를 실행하여 정책을 적용합니다.

모듈 로깅 이벤트는 이벤트 ID 4103과 함께 Windows PowerShell 이벤트 로그에 기록됩니다.

선택사항: 스크립트 사용 설정

스크립트를 사용하면 모든 PowerShell 세션 입력 및 출력의 텍스트 기반 레코드가 생성됩니다. 스크립트를 사용 설정하려면 다음 단계를 따르세요.

  1. 로컬 그룹 정책 편집기에서 컴퓨터 구성 > 관리 템플릿 > Windows 구성요소 > Windows PowerShell로 이동합니다.
  2. PowerShell 텍스트 변환 사용 설정을 더블클릭합니다.
  3. Enabled(사용 설정됨)를 선택합니다.
  4. 원하는 경우 스크립트 출력 디렉터리를 지정합니다. 비워 두면 스크립트가 각 사용자의 문서 폴더에 저장됩니다.
  5. 타임스탬프와 메타데이터를 포함하려면 호출 헤더 포함을 선택합니다.
  6. 확인을 클릭합니다.
  7. gpupdate /force를 실행하여 정책을 적용합니다.

스크립트는 PowerShell_transcript로 시작하는 이름의 텍스트 파일에 작성됩니다.

Google SecOps 수집 인증 파일 가져오기

  1. Google SecOps 콘솔에 로그인합니다.
  2. SIEM 설정 > 수집 에이전트로 이동합니다.
  3. 다운로드를 클릭하여 수집 인증 파일을 다운로드합니다.
  4. Bindplane 에이전트가 설치될 Windows 호스트에 파일을 안전하게 저장합니다.

Google SecOps 고객 ID 가져오기

  1. Google SecOps 콘솔에 로그인합니다.
  2. SIEM 설정 > 프로필로 이동합니다.
  3. 조직 세부정보 섹션에서 고객 ID를 복사하여 저장합니다.

Bindplane 에이전트 설치

다음 안내에 따라 Windows 호스트에 Bindplane 에이전트를 설치합니다.

Windows 설치

  1. 명령 프롬프트 또는 PowerShell을 관리자로 엽니다.
  2. 다음 명령어를 실행합니다.

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. 설치가 완료될 때까지 기다립니다.

  4. 다음을 실행하여 설치를 확인합니다.

    sc query observiq-otel-collector
    

    서비스가 실행 중으로 표시되어야 합니다.

추가 설치 리소스

추가 설치 옵션 및 문제 해결은 Bindplane 에이전트 설치 가이드를 참고하세요.

PowerShell 로그를 수집하도록 Bindplane 에이전트 구성

Windows 구성 파일 찾기

  • 다음과 같이 Windows 구성 파일을 찾습니다.

    notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
    

구성 파일 설정

  • config.yaml의 전체 내용을 다음 구성으로 바꿉니다.

    receivers:
      windowseventlog/powershell:
        channel: Microsoft-Windows-PowerShell/Operational
        max_reads: 100
        poll_interval: 5s
        raw: true
        start_at: end
    
    processors:
      batch:
    
    exporters:
      chronicle/powershell:
        compression: gzip
        creds_file_path: 'C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json'
        customer_id: '<CUSTOMER_ID>'
        endpoint: malachiteingestion-pa.googleapis.com
        log_type: 'POWERSHELL'
        raw_log_field: body
        override_log_type: false
    
    service:
      pipelines:
        logs/powershell:
          receivers:
            - windowseventlog/powershell
          processors:
            - batch
          exporters:
            - chronicle/powershell
    

구성 매개변수

다음 자리표시자를 바꿉니다.

  • 수신기 구성:

    • channel: 수집할 Windows 이벤트 로그 채널입니다. PowerShell 스크립트 블록 로깅의 경우 Microsoft-Windows-PowerShell/Operational을 사용합니다. 모듈 로깅의 경우 Windows PowerShell를 사용합니다.
    • raw: 원시 Windows 이벤트 로그 XML을 Google SecOps에 전송하려면 true로 설정합니다.
    • start_at: 에이전트가 시작된 후 새 이벤트만 수집하려면 end로 설정합니다. 기존의 모든 이벤트를 수집하려면 beginning로 설정합니다.
  • 내보내기 도구 구성:

    • <CUSTOMER_ID>: 이전 단계의 고객 ID로 바꿉니다.
    • creds_file_path: 수집 인증 파일의 전체 경로입니다. 다운로드한 인증 파일을 이 위치에 복사합니다.
    • endpoint: 리전 엔드포인트 URL입니다. Google SecOps 리전의 엔드포인트를 사용합니다.

      • 미국: malachiteingestion-pa.googleapis.com
      • 유럽: europe-malachiteingestion-pa.googleapis.com
      • 아시아: asia-southeast1-malachiteingestion-pa.googleapis.com
      • 전체 목록은 리전 엔드포인트를 참고하세요.
    • log_type: PowerShell 파서를 사용하려면 POWERSHELL로 설정합니다.

구성 파일 저장

수정 후 파일 > 저장을 클릭하여 파일을 저장합니다.

변경사항을 적용하려면 Bindplane 에이전트를 다시 시작하세요.

Windows

  • 명령 프롬프트 또는 PowerShell을 관리자로 사용:

    net stop observiq-otel-collector && net start observiq-otel-collector
    
  • 또는 서비스 콘솔을 사용하는 경우:

    1. Win+R 키를 누르고 services.msc을 입력한 다음 Enter 키를 누릅니다.
    2. observIQ OpenTelemetry Collector를 찾습니다.
    3. 마우스 오른쪽 버튼을 클릭하고 다시 시작을 선택합니다.
    4. 서비스가 실행 중인지 확인합니다.

      sc query observiq-otel-collector
      
    5. 로그에서 오류를 확인합니다.

      type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
      

로그 수집 확인

Bindplane 에이전트를 구성하고 서비스를 다시 시작하면 PowerShell 로그가 Google SecOps로 전송되기 시작합니다.

  1. Google SecOps 콘솔에 로그인합니다.
  2. 조사 > 검색으로 이동합니다.
  3. 다음 검색을 실행하여 PowerShell 로그가 수집되고 있는지 확인합니다.

    metadata.log_type = "POWERSHELL"
    
  4. 이벤트가 최근 타임스탬프와 함께 표시되는지 확인합니다.

PowerShell 스크립트 블록 로깅 이벤트 (이벤트 ID 4104)에는 스크립트 콘텐츠, 스크립트 블록 ID, 실행 컨텍스트를 비롯한 실행된 스크립트 블록의 세부정보가 표시됩니다.

UDM 매핑 테이블

로그 필드 UDM 매핑 논리
HostId principal.resource.product_object_id 주 리소스와 연결된 제품 객체의 고유 식별자
System.Version metadata.product_version 이벤트를 생성한 제품의 버전
System.EventId, EventID, winlog.event_id metadata.product_event_type 제품에서 정의한 이벤트 유형
컴퓨터, System.Computer, computer, winlog.computer_name principal.hostname 주체 항목의 호스트 이름
컴퓨터, System.Computer, computer, winlog.computer_name principal.asset.hostname 주 구성원과 연결된 애셋의 호스트 이름
System.EventRecordID, RecordNumber, winlog.record_id metadata.product_log_id 제품의 로깅 시스템 내 로그 항목의 고유 식별자
System.Opcode, opcode, winlog.opcode metadata.description 이벤트 설명 또는 추가 컨텍스트
ProviderGuid, winlog.provider_guid metadata.product_deployment_id 제품 배포의 고유 식별자입니다.
System.ProcessID, ProcessID, ExecutionProcessID, execution.process_id, winlog.process.pid principal.process.pid 기본 프로세스의 프로세스 ID
SourceModuleName principal.resource.name 주 구성원과 연결된 리소스의 이름
SourceModuleType principal.resource.resource_subtype 주 구성원과 연결된 리소스의 하위 유형
security.user_id, UserID, winlog.user.identifier principal.user.windows_sid 주 사용자의 Windows 보안 식별자 (SID)
metadata.event_type 이벤트 유형 (예: USER_LOGIN, NETWORK_CONNECTION)
SourceName, winlog.provider_name metadata.product_name 이벤트를 생성한 제품의 이름입니다.
AccountName, Username, UserName, winlog.user.name principal.user.userid 주 사용자의 사용자 ID
도메인, winlog.user.domain principal.administrative_domain 주체의 관리 도메인
경로, target_file, ScriptName, script_name, ContextInfo_Script Name, file_path target.process.file.full_path 타겟 프로세스와 연결된 파일의 전체 경로
HostName, powershell.Host Name, ContextInfo_Host Name target.hostname 타겟 항목의 호스트 이름
HostName, powershell.Host Name, ContextInfo_Host Name target.asset.hostname 타겟과 연결된 애셋의 호스트 이름
호스트 ID, HostID, ContextInfo_Host ID target.asset.asset_id 타겟 애셋의 고유 식별자
Nombre_de_comando, ContextInfo_Command Name, CommandName target.application 타겟과 연결된 애플리케이션의 이름
HostApplication, ContextInfo_Host Application target.process.command_line 타겟 프로세스를 실행하는 데 사용된 명령줄
ScriptBlockText target.process.command_line 타겟 프로세스를 실행하는 데 사용된 명령줄
MessageSourceAddress principal.ip 주 구성원의 IP 주소
MessageSourceAddress principal.asset.ip 주 구성원과 연결된 애셋의 IP 주소
Nombre_de_host principal.application 주 구성원과 연결된 애플리케이션의 이름
Version_de_host principal.platform_version 주 구성원과 연결된 플랫폼 버전
Id_de_host principal.resource.id 주 리소스의 고유 식별자
Application_host principal.process.file.full_path 주 프로세스와 연결된 파일의 전체 경로
HostApplication principal.process.command_line 주 프로세스를 실행하는 데 사용된 명령줄
Usuario, admin_domain principal.user.userid 주 사용자의 사용자 ID
Usuario, admin_domain principal.administrative_domain 주체의 관리 도메인
CommandLine principal.process.command_line 주 프로세스를 실행하는 데 사용된 명령줄
머신, machine_id principal.asset.asset_id 기본 저작물의 고유 식별자입니다.
머신, platform_software principal.asset.platform_software.platform 애셋의 플랫폼 유형 (예: WINDOWS, LINUX)
머신, platform_software principal.asset.platform_software.platform_version 애셋의 플랫폼 소프트웨어 버전
MessageSourceAddress intermediary.ip 중개자 법인의 IP 주소
MessageSourceAddress, Hostname intermediary.hostname 중개 기관의 호스트 이름
MessageSourceAddress, Hostname intermediary.asset.hostname 중개인과 연결된 저작물의 호스트 이름
MessageSourceAddress intermediary.port 중개자가 사용하는 포트 번호
HostApplication target.process.command_line 타겟 프로세스를 실행하는 데 사용된 명령줄
HostId target.asset.asset_id 타겟 애셋의 고유 식별자
SequenceNumber, ContextInfo_Sequence Number, Sequence Number security_result.detection_fields 추가 감지 정보의 키-값 쌍
ProviderName principal.resource.attribute.labels 주 리소스와 연결된 라벨 또는 속성
NewEngineState additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
PreviousEngineState additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
ScriptName additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
ManagementGroupName additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
소스 additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
RenderedDescription security_result.description 보안 결과 또는 취한 조치에 대한 설명
TenantId additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
사용자 이름 principal.user.userid 주 사용자의 사용자 ID
ActivityID security_result.detection_fields 추가 감지 정보의 키-값 쌍
ExecutionThreadID, execution.thread_id, winlog.process.thread.id security_result.detection_fields 추가 감지 정보의 키-값 쌍
출력 security_result.detection_fields 추가 감지 정보의 키-값 쌍
데이터 security_result.detection_fields 추가 감지 정보의 키-값 쌍
Data_1 additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
data_1 security_result.detection_fields 추가 감지 정보의 키-값 쌍
Data_2 security_result.detection_fields 추가 감지 정보의 키-값 쌍
winlog.activity_id security_result.detection_fields 추가 감지 정보의 키-값 쌍
winlog.api additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
winlog.channel principal.resource.attribute.labels 주 리소스와 연결된 라벨 또는 속성
오프셋 additional.fields 표준 UDM 스키마에 포함되지 않는 추가 맞춤 필드
SeverityValue security_result.detection_fields 추가 감지 정보의 키-값 쌍
intermediary intermediary 이벤트에 관련된 중개자 항목에 관한 세부정보
security_result security_result 작업, 심각도, 탐지를 포함한 전반적인 보안 결과
metadata.vendor_name 이벤트를 생성한 공급업체의 이름
SourceName metadata.product_name 이벤트를 생성한 제품의 이름입니다.

도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가에게 문의하여 답변을 받으세요.