CloudWatch Logs 소스

Panther 콘솔에서 CloudWatch를 데이터 전송 로그 소스로 온보딩하기

개요

Panther는 CloudWatch를 데이터 전송(Data Transport)으로 구성하여 CloudWatch에서 보안 로그를 가져와 Panther 계정으로 전송하는 구성을 지원합니다.

활성화하려면 로그 데이터의 실시간 처리arrow-up-right를 위해, Panther는 Firehose 전송 스트림arrow-up-right 과 전송 스트림의 대상으로 사용될 S3 버킷을 생성합니다. 그런 다음 CloudWatch Logs 로그 그룹에 대해 Firehose 전송 스트림을 대상으로 사용하는 구독 필터arrow-up-right 가 구성됩니다. Firehose가 새로 생성된 S3 버킷에 추가한 파일을 처리하기 위한 필요한 읽기 권한은 IAM 역할에 부여됩니다.

이 프로세스에 대한 자세한 내용은 Amazon 문서를 참조하세요: 구독에 대한 AWS CloudWatch Logs 문서arrow-up-right.

circle-exclamation

아래 다이어그램을 보면 CloudWatch Logs를 사용하여 애플리케이션에서 Panther로 데이터가 흐르는 방식을 이해할 수 있습니다( SaaS):

A diagram shows how data flows from a customer application into Panther, using the CloudWatch Data Transport. The flow is as follows: Application(s), CloudWatch log group, Subscription filter, Kinesis Firehose, S3 bucket, SNS topic, SQS, Panther application, IAM Role (assumed by Panther, S3 bucket, Panther application, parse & normalize, real-time detections, Long term retention in Snowflake, Alerts generated, Alert destination

Panther에서 CloudWatch 로그 소스를 설정하는 방법

1단계: Panther 콘솔에서 CloudWatch 구성

  1. Panther 콘솔의 왼쪽 탐색 바에서 구성 > 로그 소스.

  2. 오른쪽 상단에서 새로 만들기.

  3. 를 클릭하세요. AWS CloudWatch Logs 타일을 클릭합니다.

  4. 페이지에서, 다음 필드를 채우세요: 구성 이름

    • : CloudWatch 로그 소스의 설명적인 이름을 입력하세요.로그 그룹 이름

    • : CloudWatch 로그 그룹의 고유 이름을 입력하세요.AWS 계정 ID

    • : CloudWatch 로그 그룹이 존재하는 AWS 계정 ID 번호를 입력하세요.패턴 필터(선택 사항)

    • : 이 필드를 사용하여 CloudWatch에서 수신된 로그 데이터를 필터링할 수 있습니다. 필터 및 패턴 문법에 대한 자세한 내용은Amazon의 필터 및 패턴 문법 문서 을 참조하세요.arrow-up-right.

    • 로그 유형: Panther가 CloudWatch 로그를 파싱할 때 사용할 로그 유형을 선택하세요. 드롭다운 메뉴에서 최소 하나의 로그 유형을 선택해야 합니다.

  5. 클릭 설정.

2단계: IAM 역할 설정

소스에서 객체를 읽기 위해 Panther는 특정 권한을 가진 AWS IAM 역할이 필요합니다. 이 역할을 설정하려면 다음 옵션 중 선택할 수 있습니다:

  • AWS 콘솔 UI 사용

    • Panther에서 이 데이터 전송 소스를 처음 설정하는 경우 이 옵션을 선택하세요.

  • CloudFormation 또는 Terraform 파일

  • 모든 것을 직접 설정하겠습니다

On the IAM Role Setup page, there are three options: Using the AWS Console UI, CloudFormation or Terraform File, or I want to set everything up on my own

AWS 콘솔 UI 사용

AWS 콘솔을 사용하여 CloudFormation 스택을 시작하세요:

  1. 페이지에서, 다음 필드를 채우세요: IAM 역할 생성 페이지에서, AWS 콘솔 UI 사용 타일에서, 클릭 계속.

  2. 클릭 콘솔 시작.

    • 템플릿 URL이 미리 채워진 상태로 새 브라우저 탭에서 AWS 콘솔로 리디렉션됩니다.

    • CloudFormation 스택은 소스에서 객체를 읽기 위해 필요한 최소 권한을 가진 AWS IAM 역할을 생성합니다.

    • AWS의 CloudFormation 스택에서 "Outputs" 탭을 클릭하고 Role ARN을 기록하세요.

  3. Panther 콘솔로 돌아가서 다음 필드에 값을 입력하세요:

    • (S3 소스를 설정하는 경우 해당되지 않음) 버킷 이름 – 필수: 출력된 S3 버킷 이름을 입력하세요.

    • 역할 ARN – 필수: 출력된 IAM 역할 ARN을 입력하세요.

  4. 클릭 설정.

아래의 "수동 IAM 역할 생성: 추가 단계" 섹션으로 진행하세요.

3단계: 소스 설정 완료

The success screen reads, "Everything looks good! Panther will now automatically pull & process logs from your account"
The "Trigger an alert when no events are processed" toggle is set to YES. The "How long should Panther wait before it sends you an alert that no events have been processed" setting is set to 1 Day
  • 입니다. 데이터가 일정 기간 동안 로그 소스에서 흐르지 않으면 경고를 받도록 이 설정을 활성화된 상태로 두는 것을 권장합니다. 시간 범위는 구성 가능하며 기본값은 24시간입니다. 아직 수행하지 않았다면, 클릭하세요 스키마 연결 또는 유추

을 클릭하여 소스에 하나 이상의 스키마를 연결하세요.

엔벨로프 필드 보존 선택적으로 CloudWatch Logs의 엔벨로프 메타데이터(예:, ownerlogGroup logStream )를 각 처리된 이벤트의 p_header

필드에 보존할 수 있습니다. 이 옵션은 CloudWatch Logs 스트림 유형을 사용하는 모든 소스에서 사용 가능합니다.

기존 CloudWatch 로그 소스에 대한 엔벨로프 필드 구성

  1. Panther 콘솔의 왼쪽 탐색 바에서 구성 > 로그 소스.

  2. 기존 CloudWatch 로그 소스가 있고 엔벨로프 필드 보존을 활성화하거나 비활성화하려는 경우, 소스가 생성된 후에 이 설정을 구성할 수 있습니다:

  3. 목록에서 CloudWatch 로그 소스를 찾아 클릭하세요. 클릭하세요 구성

  4. 를 클릭하세요. 탭을. 편집 아이콘 스트림 유형.

  5. 옆에 있는 "엔벨로프 필드 보존" )를 각 처리된 이벤트의 필드의 스위치를 켜세요.

  6. 클릭 선택 적용 을 클릭하여 변경사항을 저장하세요.

CloudWatch Logs 엔벨로프 메타데이터

엔벨로프 필드 보존이 활성화되면, )를 각 처리된 이벤트의 필드에는 다음 CloudWatch 메타데이터를 포함한 JSON 객체가 들어 있습니다:

  • 선택적으로 CloudWatch Logs의 엔벨로프 메타데이터(예:: 로그 그룹의 소유자 AWS 계정 ID

  • owner: CloudWatch 로그 그룹의 이름

  • : CloudWatch 로그 스트림의 이름

  • subscriptionFilters: 로그 그룹에 구성된 구독 필터 이름의 배열

예시 )를 각 처리된 이벤트의 내용:

수집된 로그 보기

로그 소스가 구성된 후에는 다음을 사용하여 수집된 데이터를 검색할 수 있습니다: 검색 또는 데이터 탐색기.

수동 IAM 역할 생성: 추가 단계

로그 소스 생성 중 IAM 역할을 수동으로 설정하도록 선택한 경우, 새 데이터가 도착할 때 알림을 보내도록 S3 버킷을 구성하는 아래 지침도 따라야 합니다.

1단계: SNS 주제 생성 또는 수정

SNS 주제 생성 방법

참고: 이미 버킷이 모든 객체 생성 이벤트 를 SNS 주제로 전송하도록 구성되어 있다면, 대신 "기존 SNS 주제 수정" 탭을 따라 해당 주제를 Panther의 입력 데이터 큐에 구독시키십시오.

circle-info

AWS 계정당 하나의 SNS 주제만 필요하므로 하나의 AWS 계정 내 여러 S3 버킷이 동일한 SNS 주제를 사용할 수 있습니다. 동일한 AWS 계정의 다른 S3 버킷용으로 이미 SNS 주제를 생성했다면 이 단계를 건너뛸 수 있습니다.

먼저 Panther에 새 데이터가 처리 준비가 되었음을 알리기 위해 SNS 주제와 SNS 구독을 생성해야 합니다.

  1. S3 버킷을 소유한 계정의 AWS 콘솔에 로그인하세요.

  2. S3 버킷이 위치한 AWS 리전을 선택하고 CloudFormation 콘솔로 이동하세요.

  3. 로 이동하여 스택 섹션에서 스택 생성 (새 리소스 포함)을 선택하세요. In the AWS CloudFormation console, there is a "Create Stack" dropdown menu in the upper right. In this image, the menu is expanded and the option "with new resources (standard)" is highlighted.

  4. "템플릿 지정" 섹션에 다음 Amazon S3 URL을 입력하세요:

  5. 다음 스택 세부 정보를 지정하세요:

    • 스택 이름: 원하는 이름, 예: panther-log-processing-notifications-<bucket-label>

    • 마스터계정ID: Panther가 배포된 12자리 AWS 계정 ID

    • Panther 리전: Panther가 배포된 리전

    • SnsTopicName: 알림을 수신할 SNS 주제의 이름. 기본값은 panther-notifications-topic

  6. 클릭 다음, 다음을 클릭한 다음 스택 생성 을 클릭하여 프로세스를 완료하세요.

    • 이 스택에는 하나의 출력이 있습니다: SnsTopicArn.

2단계: S3 버킷에서 이벤트 알림 구성

SNS 주제가 생성되었으면 마지막 단계는 S3 버킷에서 알림을 활성화하는 것입니다.

  1. AWS의 S3 콘솔arrow-up-right로 이동하여 관련 버킷을 선택한 다음 속성 구성

  2. 을 클릭하세요. 에서 카드를 찾으세요.

  3. 클릭 이벤트 알림 생성 을 찾고 다음 설정을 사용하세요:

    • 일반 구성 섹션에서: 이벤트 이름

      • PantherEventNotifications: 접두사

      • (선택 사항): 객체 키가 특정 문자로 시작하는 경우에만 알림을 제한합니다. 접미사

      • (선택 사항): 객체 키가 특정 문자로 끝나는 경우에만 알림을 제한합니다. 이벤트 유형

      • 일반 구성 카드에서, 다음 옆의 박스를 체크하세요 모든 객체 생성 이벤트.

circle-info

중복되는 접두사와 접미사를 사용하는 여러 필터 생성 피하기 . 그렇지 않으면 구성은 유효하지 않은 것으로 간주됩니다.arrow-up-right대상

  • 일반 구성 카드: 에서

    • 아래에서, 카드:SNS 주제 를 선택하세요..

    • 대상으로 를 선택하세요.이전에 생성하거나 수정한 SNS 주제를 선택하세요.

      • 제공된 CloudFormation 템플릿에서 기본 주제 이름을 사용한 경우 SNS 주제 이름은 panther-notifications-topic.

      • 입니다.

사용자 지정 SNS 주제를 사용하는 경우 올바른 정책이 설정되어 있고 Panther SQS 큐에 대한 구독이 있는지 확인하세요. 4. 클릭.

  • 저장하세요(저장). 버튼을 클릭하세요. (원문: "Save")의 의미로 번역됨.)

마지막 업데이트

도움이 되었나요?