AWS EC2 인스턴스 로그 수집

다음에서 지원:

이 문서에서는 모니터링 및 분석을 위해 AWS EC2 인스턴스 로그를 Google Security Operations로 구성하는 방법을 설명합니다. 파서는 인스턴스 예약 JSON 로그에서 데이터를 추출하고 UDM을 준수하도록 필드를 재구성하고 이름을 바꿉니다. 네트워크 인터페이스, 그룹, 태그를 비롯한 다양한 데이터 유형과 중첩된 구조를 처리하는 동시에 애셋 관계와 메타데이터를 생성합니다. 또한 오류 처리 및 잘못된 JSON 메시지 삭제도 실행합니다.

시작하기 전에

  • Google SecOps 인스턴스가 있는지 확인합니다.
  • AWS에 대한 권한 액세스 권한이 있는지 확인합니다.

AWS IAM 및 S3 구성

  1. 이 사용자 가이드(버킷 만들기)에 따라 Amazon S3 버킷을 만듭니다.
  2. 나중에 사용할 수 있도록 버킷 이름리전을 저장합니다.
  3. 이 사용자 가이드(IAM 사용자 만들기)에 따라 사용자를 만듭니다.
  4. 생성된 사용자를 선택합니다.
  5. 보안 사용자 인증 정보 탭을 선택합니다.
  6. 액세스 키 섹션에서 액세스 키 만들기를 클릭합니다.
  7. 사용 사례서드 파티 서비스를 선택합니다.
  8. 다음을 클릭합니다.
  9. 선택사항: 설명 태그를 추가합니다.
  10. 액세스 키 만들기를 클릭합니다.
  11. CSV 파일 다운로드를 클릭하여 나중에 사용할 수 있도록 액세스 키비밀 액세스 키를 저장합니다.
  12. 완료를 클릭합니다.
  13. 권한 탭을 선택합니다.
  14. 권한 정책 섹션에서 권한 추가를 클릭합니다.
  15. 권한 추가를 선택합니다.
  16. 정책 직접 연결을 선택합니다.
  17. AmazonS3FullAccess 정책을 검색하여 선택합니다.
  18. 다음을 클릭합니다.
  19. 권한 추가를 클릭합니다.

CloudWatch Logs로 로그를 전송하도록 EC2 구성

  1. SSH를 사용하여 EC2 인스턴스에 연결하고 인증을 위해 키 쌍을 제공합니다.

    ssh -i your-key.pem ec2-user@your-ec2-public-ip
    
  2. CloudWatch Logs 에이전트를 설치합니다.

    • Amazon Linux에 CloudWatch Logs 에이전트를 설치하려면 다음 명령어를 사용하세요.
    sudo yum install -y awslogs
    
    • Ubuntu에 CloudWatch Logs 에이전트를 설치하려면 다음 명령어를 사용하세요.
    sudo apt-get install -y awslogs
    
  3. CloudWatch Logs 구성 파일을 엽니다.

    sudo vi /etc/awslogs/awslogs.conf
    
  4. 이 로그 인스턴스 메타데이터를 가져와 파일에 쓰는 스크립트를 만듭니다.

    #!/bin/bash
    echo "Architecture: $(curl -s http://169.254.169.254/latest/meta-data/architecture)" >> /var/log/instance_metadata.log
    echo "AmiLaunchIndex: $(curl -s http://169.254.169.254/latest/meta-data/ami-launch-index)" >> /var/log/instance_metadata.log
    echo "BootMode: $(curl -s http://169.254.169.254/latest/meta-data/boot-mode)" >> /var/log/instance_metadata.log
    
  5. 스크립트를 /etc/init.d/metadata_script.sh로 저장하고 crontab 또는 rc.local를 사용하여 인스턴스 시작 시 실행합니다.

  6. CloudWatch Logs 에이전트의 구성 파일을 엽니다.

    sudo vi /etc/awslogs/awslogs.conf
    
  7. 구성 파일에 다음을 추가합니다.

    [/var/log/messages]
    file = /var/log/messages
    log_group_name = /ec2/system/logs
    log_stream_name = {instance_id}
    
    [/var/log/secure]
    file = /var/log/secure
    log_group_name = /ec2/security/logs
    log_stream_name = {instance_id}
    
    [/var/log/auth.log]
    file = /var/log/auth.log
    log_group_name = /ec2/auth/logs
    log_stream_name = {instance_id}
    
    [/var/log/httpd/access_log]
    file = /var/log/httpd/access_log
    log_group_name = /ec2/application/apache/access_logs
    log_stream_name = {instance_id}
    
    [/var/log/httpd/error_log]
    file = /var/log/httpd/error_log
    log_group_name = /ec2/application/apache/error_logs
    log_stream_name = {instance_id}
    
  8. 구성을 저장하고 편집기를 종료합니다.

  9. CloudWatch Logs 에이전트를 시작합니다.

    • Amazon Linux의 경우:
    sudo service awslogs start
    
    • Ubuntu:
    sudo service awslogs start
    
  10. 에이전트가 실행 중인지 확인합니다.

    sudo service awslogs status
    

Lambda 및 S3에 대한 IAM 권한 구성

  1. AWS IAM 콘솔에서 다음 권한으로 새 IAM 역할을 만듭니다.

    • logs:PutSubscriptionFilter
    • logs:DescribeLogGroups
    • logs:GetLogEvents
    • s3:PutObject
  2. 로그를 S3로 내보내는 Lambda 함수에 이 역할을 연결합니다.

로그를 S3로 내보내도록 Lambda 구성

  1. Lambda 콘솔로 이동하여 새 함수를 만듭니다.

    import boto3
    import gzip
    from io import BytesIO
    
    s3 = boto3.client('s3')
    logs = boto3.client('logs')
    
    def lambda_handler(event, context):
        log_group = event['logGroup']
        log_stream = event['logStream']
    
        log_events = logs.get_log_events(
            logGroupName=log_group,
            logStreamName=log_stream,
            startFromHead=True
        )
    
        log_data = "\n".join([event['message'] for event in log_events['events']])
    
        # Compress and upload to S3
        compressed_data = gzip.compress(log_data.encode('utf-8'))
        s3.put_object(
            Bucket='your-s3-bucket-name',
            Key='logs/ec2-log.gz',
            Body=compressed_data
        )
      ```
    
    • your-s3-bucket-name을 실제 S3 버킷 이름으로 바꿉니다.
  2. 앞에서 만든 Lambda 함수에 IAM 역할을 연결합니다.

  3. CloudWatch 콘솔에서 로그 섹션으로 이동합니다.

  4. 로그 그룹을 선택합니다(예: /ec2/system/logs).

  5. 작업 > 구독 필터 만들기를 클릭합니다.

  6. 대상을 이전에 만든 Lambda 함수로 설정합니다.

AWS EC2 인스턴스 로그를 수집하도록 Google SecOps에서 피드 구성

  1. SIEM 설정> 피드로 이동합니다.
  2. 새로 추가를 클릭합니다.
  3. 피드 이름 필드에 피드 이름을 입력합니다(예: AWS EC2 인스턴스 로그).
  4. 소스 유형으로 Amazon S3 V2를 선택합니다.
  5. 로그 유형으로 AWS EC2 인스턴스를 선택합니다.
  6. 다음을 클릭합니다.
  7. 다음 입력 매개변수의 값을 지정합니다.

    • S3 URI: 버킷 URI입니다.
      • s3://your-log-bucket-name/
        • your-log-bucket-name을 버킷의 실제 이름으로 바꿉니다.
    • 소스 삭제 옵션: 환경설정에 따라 삭제 옵션을 선택합니다.

    • 최대 파일 기간: 지난 일수 동안 수정된 파일을 포함합니다. 기본값은 180일입니다.

    • 액세스 키 ID: s3 버킷에 액세스할 수 있는 사용자 액세스 키입니다.

    • 보안 비밀 액세스 키: s3 버킷에 액세스할 수 있는 사용자 보안 비밀 키입니다.

    • 애셋 네임스페이스: 애셋 네임스페이스입니다.

    • 수집 라벨: 이 피드의 이벤트에 적용할 라벨입니다.

  8. 다음을 클릭합니다.

  9. 확정 화면에서 새 피드 구성을 검토한 다음 제출을 클릭합니다.

UDM 매핑 테이블

로그 필드 UDM 매핑 논리
Architecture entity.entity.asset.attribute.labels.key=instances_set_architecture, entity.entity.asset.attribute.labels.value 값은 원시 로그의 Instances.Architecture 필드에서 직접 가져옵니다.
AmiLaunchIndex entity.entity.asset.attribute.labels.key=instances_set_ami_launch_index, entity.entity.asset.attribute.labels.value 값은 원시 로그의 Instances.AmiLaunchIndex 필드에서 직접 가져옵니다.
BlockDeviceMapping.Ebs.AttachTime entity.entity.resource_ancestors.attribute.labels.key=instances_set_block_device_mapping_ebs_attach_time, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.BlockDeviceMapping.Ebs.AttachTime에서 가져옵니다.
BlockDeviceMapping.Ebs.DeleteOnTermination entity.entity.resource_ancestors.attribute.labels.key=instances_set_block_device_mapping_ebs_delete_on_termination, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.BlockDeviceMapping.Ebs.DeleteOnTermination에서 가져옵니다.
BlockDeviceMapping.Ebs.Status entity.entity.resource_ancestors.attribute.labels.key=instances_set_block_device_mapping_ebs_volume_status, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.BlockDeviceMapping.Ebs.Status에서 가져옵니다.
BlockDeviceMapping.Ebs.VolumeID entity.entity.resource_ancestors.product_object_id, entity.entity.resource_ancestors.resource_type=VOLUME 값은 Instances.BlockDeviceMapping.Ebs.VolumeID에서 가져옵니다.
BlockDeviceMapping.Name entity.entity.resource_ancestors.attribute.labels.key=instances_set_block_device_mapping_device_name, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.BlockDeviceMapping.Name에서 가져옵니다.
BootMode entity.entity.asset.attribute.labels.key=instances_set_boot_mode, entity.entity.asset.attribute.labels.value 값은 Instances.BootMode에서 가져옵니다.
CapacityReservationID entity.entity.asset.attribute.labels.key=instances_set_capacity_reservation_id, entity.entity.asset.attribute.labels.value 값은 Instances.CapacityReservationID에서 가져옵니다.
CapacityReservationSpecification.CapacityReservationPreference entity.entity.asset.attribute.labels.key=instances_set_capacity_reservation_specification_capacity_reservation_preference, entity.entity.asset.attribute.labels.value 값은 Instances.CapacityReservationSpecification.CapacityReservationPreference에서 가져옵니다.
CapacityReservationSpecification.CapacityReservationTarget.CapacityReservationID entity.entity.asset.attribute.labels.key=instances_set_capacity_reservation_specification_capacity_reservation_target_capacity_reservation_id, entity.entity.asset.attribute.labels.value 값은 Instances.CapacityReservationSpecification.CapacityReservationTarget.CapacityReservationID에서 가져옵니다.
CapacityReservationSpecification.CapacityReservationTarget.CapacityReservationResourceGroupArn entity.entity.resource_ancestors.name, entity.entity.resource_ancestors.resource_subtype=Capacity Reservation Arn 값은 Instances.CapacityReservationSpecification.CapacityReservationTarget.CapacityReservationResourceGroupArn에서 가져옵니다.
ClientToken entity.entity.asset.attribute.labels.key=instances_set_client_token, entity.entity.asset.attribute.labels.value 값은 Instances.ClientToken에서 가져옵니다.
CPU.AmdSevSnp entity.entity.asset.attribute.labels.key=instances_set_cpu_options_amd_sev_snp, entity.entity.asset.attribute.labels.value 값은 Instances.CPU.AmdSevSnp에서 가져옵니다.
CPU.CoreCount entity.entity.asset.hardware.cpu_number_cores 값은 Instances.CPU.CoreCount에서 가져옵니다.
CPU.ThreadsPerCore entity.entity.asset.attribute.labels.key=instances_set_cpu_options_threads_per_core, entity.entity.asset.attribute.labels.value 값은 Instances.CPU.ThreadsPerCore에서 가져옵니다.
CurrentInstanceBootMode entity.entity.asset.attribute.labels.key=instances_set_current_instance_boot_mode, entity.entity.asset.attribute.labels.value 값은 Instances.CurrentInstanceBootMode에서 가져옵니다.
DNSName entity.entity.network.dns_domain 값은 Instances.DNSName에서 가져옵니다.
EbsOptimized entity.entity.asset.attribute.labels.key=instances_set_ebs_optimized, entity.entity.asset.attribute.labels.value 값은 Instances.EbsOptimized에서 가져옵니다.
ElasticGpuAssociationSet.ElasticGpuAssociationID entity.entity.asset.attribute.labels.key=instances_set_elastic_gpu_association_set_elastic_gpu_association_id, entity.entity.asset.attribute.labels.value 값은 Instances.ElasticGpuAssociationSet.ElasticGpuAssociationID에서 가져옵니다.
ElasticGpuAssociationSet.ElasticGpuAssociationState entity.entity.asset.attribute.labels.key=instances_set_elastic_gpu_association_set_elastic_gpu_association_state, entity.entity.asset.attribute.labels.value 값은 Instances.ElasticGpuAssociationSet.ElasticGpuAssociationState에서 가져옵니다.
ElasticGpuAssociationSet.ElasticGpuAssociationTime entity.entity.asset.attribute.labels.key=instances_set_elastic_gpu_association_set_elastic_gpu_association_time, entity.entity.asset.attribute.labels.value 값은 Instances.ElasticGpuAssociationSet.ElasticGpuAssociationTime에서 가져옵니다.
ElasticGpuAssociationSet.ElasticGpuID entity.entity.asset.attribute.labels.key=instances_set_elastic_gpu_association_set_elastic_gpu_id, entity.entity.asset.attribute.labels.value 값은 Instances.ElasticGpuAssociationSet.ElasticGpuID에서 가져옵니다.
ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorArn entity.entity.resource_ancestors.name, entity.entity.resource_ancestors.resource_subtype=Elastic Interface Accelerator Arn 값은 Instances.ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorArn에서 가져옵니다.
ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationID entity.entity.resource_ancestors.attribute.labels.key=instances_set_elastic_inference_accelerator_association_set_elastic_inference_accelerator_association_id, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationID에서 가져옵니다.
ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationState entity.entity.resource_ancestors.attribute.labels.key=instances_set_elastic_inference_accelerator_association_set_elastic_inference_accelerator_association_state, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationState에서 가져옵니다.
ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationTime entity.entity.resource_ancestors.attribute.labels.key=instances_set_elastic_inference_accelerator_association_set_elastic_inference_accelerator_association_time, entity.entity.resource_ancestors.attribute.labels.value 값은 Instances.ElasticInferenceAcceleratorAssociationSet.ElasticInferenceAcceleratorAssociationTime에서 가져옵니다.
EnaSupport entity.entity.asset.attribute.labels.key=instances_set_ena_support, entity.entity.asset.attribute.labels.value 값은 Instances.EnaSupport에서 가져옵니다.
EnclaveOptions.Enabled entity.entity.asset.attribute.labels.key=instances_set_enclave_options_enabled, entity.entity.asset.attribute.labels.value 값은 Instances.EnclaveOptions.Enabled에서 가져옵니다.
GroupSet.GroupID entity.entity.group.product_object_id, entity.entity.group.attribute.labels.key=group_set_group_id, entity.entity.group.attribute.labels.value, entity.entity.group.attribute.labels.key=instances_set_group_set_group_id, entity.entity.group.attribute.labels.value, entity.entity.group.attribute.labels.key=instances_set_network_interface_set_group_set_group_id, entity.entity.group.attribute.labels.value 값은 GroupSet.GroupID에서 가져옵니다. 배열의 첫 번째 GroupIDentity.entity.group.product_object_id에 매핑됩니다. 후속 GroupID 값은 라벨로 매핑됩니다.
GroupSet.GroupName entity.entity.group.group_display_name, entity.entity.group.attribute.labels.key=group_set_group_name, entity.entity.group.attribute.labels.value, entity.entity.group.attribute.labels.key=instances_set_group_set_group_name, entity.entity.group.attribute.labels.value, entity.entity.group.attribute.labels.key=instances_set_network_interface_set_group_set_group_name, entity.entity.group.attribute.labels.value 값은 GroupSet.GroupName에서 가져옵니다. 배열의 첫 번째 GroupNameentity.entity.group.group_display_name에 매핑됩니다. 후속 GroupName 값은 라벨로 매핑됩니다.
HibernationOptions entity.entity.asset.attribute.labels.key=instances_set_hibernation_options, entity.entity.asset.attribute.labels.value 값은 Instances.HibernationOptions에서 가져옵니다.
HibernationOptions.Configured entity.entity.asset.attribute.labels.key=instances_set_hibernation_options_configured, entity.entity.asset.attribute.labels.value 값은 Instances.HibernationOptions.Configured에서 가져옵니다.
Hypervisor entity.entity.asset.attribute.labels.key=instances_set_hypervisor, entity.entity.asset.attribute.labels.value 값은 Instances.Hypervisor에서 가져옵니다.
IamInstanceProfile.Arn entity.entity.resource_ancestors.name, entity.entity.resource_ancestors.resource_subtype=Instance Profile Arn 값은 Instances.IamInstanceProfile.Arn에서 가져옵니다.
IamInstanceProfile.ID entity.entity.resource_ancestors.product_object_id 값은 Instances.IamInstanceProfile.ID에서 가져옵니다.
ImageID entity.entity.resource_ancestors.product_object_id, entity.entity.resource_ancestors.resource_type=IMAGE 값은 Instances.ImageID에서 가져옵니다.
InstanceID entity.metadata.product_entity_id, entity.entity.asset.asset_id 값은 Instances.InstanceID에서 가져옵니다.
InstanceLifecycle entity.entity.asset.attribute.labels.key=instances_set_instance_lifecycle, entity.entity.asset.attribute.labels.value 값은 Instances.InstanceLifecycle에서 가져옵니다.
InstanceState.Code entity.entity.asset.attribute.labels.key=instances_set_instance_state_code, entity.entity.asset.attribute.labels.value 값은 Instances.InstanceState.Code에서 가져옵니다.
InstanceState.Name entity.entity.asset.deployment_status 값은 Instances.InstanceState.Name에서 파생됩니다. 값이 running인 경우 UDM 필드가 ACTIVE로 설정됩니다. 값이 shutting-down 또는 stopping인 경우 UDM 필드가 PENDING_DECOMMISSION로 설정됩니다. 값이 stopped 또는 terminated인 경우 UDM 필드가 DECOMMISSIONED로 설정됩니다.
InstanceType entity.entity.asset.category 값은 Instances.InstanceType에서 가져옵니다.
IPAddress entity.entity.asset.ip 값은 Instances.IPAddress에서 가져옵니다.
Ipv6Address entity.entity.asset.ip 값은 Instances.Ipv6Address에서 가져옵니다.
KernelID entity.entity.asset.attribute.labels.key=instances_set_kernel_id, entity.entity.asset.attribute.labels.value 값은 Instances.KernelID에서 가져옵니다.
KeyName entity.entity.asset.attribute.labels.key=instances_set_key_name, entity.entity.asset.attribute.labels.value 값은 Instances.KeyName에서 가져옵니다.
LaunchTime entity.metadata.creation_timestamp 값은 Instances.LaunchTime에서 가져옵니다.
LicenseSet.LicenseConfigurationArn entity.entity.resource_ancestors.name, entity.entity.resource_ancestors.resource_subtype=License Configuration Arn 값은 Instances.LicenseSet.LicenseConfigurationArn에서 가져옵니다.
MaintenanceOptions entity.entity.asset.attribute.labels.key=instances_set_maintenance_options_auto_recovery, entity.entity.asset.attribute.labels.value 값은 Instances.MaintenanceOptions에서 가져옵니다.
MetadataOptions.HTTPEndpoint entity.entity.asset.attribute.labels.key=instances_set_metadata_options_http_endpoint, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.HTTPEndpoint에서 가져옵니다.
MetadataOptions.HTTPProtocolIpv6 entity.entity.asset.attribute.labels.key=instances_set_metadata_options_http_protocol_ipv6, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.HTTPProtocolIpv6에서 가져옵니다.
MetadataOptions.HTTPPutResponseHopLimit entity.entity.asset.attribute.labels.key=instances_set_metadata_options_http_put_response_hop_limit, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.HTTPPutResponseHopLimit에서 가져옵니다.
MetadataOptions.HTTPTokens entity.entity.asset.attribute.labels.key=instances_set_metadata_options_http_tokens, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.HTTPTokens에서 가져옵니다.
MetadataOptions.InstanceMetadataTags entity.entity.asset.attribute.labels.key=instances_set_metadata_options_instance_metadata_tags, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.InstanceMetadataTags에서 가져옵니다.
MetadataOptions.State entity.entity.asset.attribute.labels.key=instances_set_metadata_options_state, entity.entity.asset.attribute.labels.value 값은 Instances.MetadataOptions.State에서 가져옵니다.
Monitoring.State entity.entity.asset.attribute.labels.key=instances_set_monitoring_state, entity.entity.asset.attribute.labels.value 값은 Instances.Monitoring.State에서 가져옵니다.
NetworkInterfaceSet.Association.CarrierIP entity.entity.asset.nat_ip 값은 Instances.NetworkInterfaceSet.Association.CarrierIP에서 가져옵니다.
NetworkInterfaceSet.Association.CustomerOwnedIP entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_association_customer_owned_ip, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Association.CustomerOwnedIP에서 가져옵니다.
NetworkInterfaceSet.Association.IPOwnerID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_association_ip_owner_id, entity.entity.asset.attribute.labels.value, entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_private_ip_addresses_set_association_ip_owner_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Association.IPOwnerID에서 가져옵니다.
NetworkInterfaceSet.Association.PublicDNSName entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_association_public_dns_name, entity.entity.asset.attribute.labels.value, entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_private_ip_addresses_set_association_public_dns_name, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Association.PublicDNSName에서 가져옵니다.
NetworkInterfaceSet.Association.PublicIP entity.entity.asset.ip 값은 Instances.NetworkInterfaceSet.Association.PublicIP에서 가져옵니다.
NetworkInterfaceSet.Attachment.AttachTime entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_attach_time, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.AttachTime에서 가져옵니다.
NetworkInterfaceSet.Attachment.AttachmentID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_attachment_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.AttachmentID에서 가져옵니다.
NetworkInterfaceSet.Attachment.DeleteOnTermination entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_delete_on_termination, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.DeleteOnTermination에서 가져옵니다.
NetworkInterfaceSet.Attachment.DeviceIndex entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_device_index, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.DeviceIndex에서 가져옵니다.
NetworkInterfaceSet.Attachment.NetworkCardIndex entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_network_card_index, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.NetworkCardIndex에서 가져옵니다.
NetworkInterfaceSet.Attachment.Status entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_attachment_status, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Attachment.Status에서 가져옵니다.
NetworkInterfaceSet.Description entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_description, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Description에서 가져옵니다.
NetworkInterfaceSet.GroupSet.GroupID entity.entity.group.attribute.labels.key=instances_set_network_interface_set_group_set_group_id, entity.entity.group.attribute.labels.value 값은 Instances.NetworkInterfaceSet.GroupSet.GroupID에서 가져옵니다.
NetworkInterfaceSet.GroupSet.GroupName entity.entity.group.attribute.labels.key=instances_set_network_interface_set_group_set_group_name, entity.entity.group.attribute.labels.value 값은 Instances.NetworkInterfaceSet.GroupSet.GroupName에서 가져옵니다.
NetworkInterfaceSet.InterfaceType entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_interface_type, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.InterfaceType에서 가져옵니다.
NetworkInterfaceSet.Ipv6AddressesSet.Ipv6Address entity.entity.asset.ip 값은 Instances.NetworkInterfaceSet.Ipv6AddressesSet.Ipv6Address에서 가져옵니다.
NetworkInterfaceSet.Ipv6AddressesSet.IsPrimaryIpv6 entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_ipv6_addresses_set_is_primary_ipv6, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Ipv6AddressesSet.IsPrimaryIpv6에서 가져옵니다.
NetworkInterfaceSet.MacAddress entity.entity.asset.mac 값은 Instances.NetworkInterfaceSet.MacAddress에서 가져옵니다.
NetworkInterfaceSet.NetworkInterfaceID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_network_interface_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.NetworkInterfaceID에서 가져옵니다.
NetworkInterfaceSet.OwnerID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_owner_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.OwnerID에서 가져옵니다.
NetworkInterfaceSet.PrivateDNSName entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_private_dns_name, entity.entity.asset.attribute.labels.value, entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_private_ip_addresses_set_private_dns_name, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.PrivateDNSName에서 가져옵니다.
NetworkInterfaceSet.PrivateIPAddress entity.entity.asset.ip 값은 Instances.NetworkInterfaceSet.PrivateIPAddress에서 가져옵니다.
NetworkInterfaceSet.PrivateIPAddressesSet.Primary entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_private_ip_addresses_set_primary, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.PrivateIPAddressesSet.Primary에서 가져옵니다.
NetworkInterfaceSet.PrivateIPAddressesSet.PrivateIPAddress entity.entity.asset.ip 값은 Instances.NetworkInterfaceSet.PrivateIPAddressesSet.PrivateIPAddress에서 가져옵니다.
NetworkInterfaceSet.SourceDestCheck entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_source_dest_check, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.SourceDestCheck에서 가져옵니다.
NetworkInterfaceSet.Status entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_status, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.Status에서 가져옵니다.
NetworkInterfaceSet.SubnetID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_subnet_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.SubnetID에서 가져옵니다.
NetworkInterfaceSet.VpcID entity.entity.asset.attribute.labels.key=instances_set_network_interface_set_vpc_id, entity.entity.asset.attribute.labels.value 값은 Instances.NetworkInterfaceSet.VpcID에서 가져옵니다.
OutpostArn entity.relations.entity.asset.product_object_id 값은 Instances.OutpostArn에서 가져옵니다.
Placement.Affinity entity.entity.asset.attribute.labels.key=instances_set_placement_affinity, entity.entity.asset.attribute.labels.value 값은 Instances.Placement.Affinity에서 가져옵니다.
Placement.AvailabilityZone entity.entity.asset.attribute.cloud.availability_zone 값은 Instances.Placement.AvailabilityZone에서 가져옵니다.
Placement.GroupID entity.entity.group.attribute.labels.key=instances_set_placement_group_id, entity.entity.group.attribute.labels.value 값은 Instances.Placement.GroupID에서 가져옵니다.
Placement.GroupName entity.entity.group.attribute.labels.key=instances_set_placement_group_name, entity.entity.group.attribute.labels.value 값은 Instances.Placement.GroupName에서 가져옵니다.
Placement.HostID entity.relations.entity.asset.asset_id 값은 Instances.Placement.HostID에서 가져옵니다.
Placement.HostResourceGroupArn entity.relations.entity.asset.attribute.labels.key=instances_set_placement_host_resource_group_arn, entity.relations.entity.asset.attribute.labels.value 값은 Instances.Placement.HostResourceGroupArn에서 가져옵니다.
Placement.PartitionNumber entity.entity.asset.attribute.labels.key=instances_set_placement_partition_number, entity.entity.asset.attribute.labels.value 값은 Instances.Placement.PartitionNumber에서 가져옵니다.
Placement.SpreadDomain entity.entity.asset.attribute.labels.key=instances_set_placement_spread_domain, entity.entity.asset.attribute.labels.value 값은 Instances.Placement.SpreadDomain에서 가져옵니다.
Placement.Tenancy entity.entity.asset.attribute.labels.key=instances_set_placement_tenancy, entity.entity.asset.attribute.labels.value 값은 Instances.Placement.Tenancy에서 가져옵니다.
PlatformDetails entity.entity.asset.attribute.labels.key=instances_set_platform_details, entity.entity.asset.attribute.labels.value 값은 Instances.PlatformDetails에서 가져옵니다.
PrivateDNSName entity.entity.network.dns.questions.name 값은 Instances.PrivateDNSName에서 가져옵니다.
PrivateDNSNameOptions.EnableResourceNameDnsAAAARecord entity.entity.network.dns.questions.type 값이 true이면 UDM 필드가 28로 설정됩니다.
PrivateDNSNameOptions.EnableResourceNameDnsARecord entity.entity.network.dns.questions.type 값이 true이면 UDM 필드가 1로 설정됩니다.
PrivateDNSNameOptions.HostnameType entity.entity.asset.attribute.labels.key=instances_set_private_dns_name_options_hostname_type, entity.entity.asset.attribute.labels.value 값은 Instances.PrivateDNSNameOptions.HostnameType에서 가져옵니다.
PrivateIPAddress entity.entity.asset.ip 값은 Instances.PrivateIPAddress에서 가져옵니다.
ProductCodes.ProductCode entity.entity.asset.attribute.labels.key=instances_set_product_codes_product_code, entity.entity.asset.attribute.labels.value 값은 Instances.ProductCodes.ProductCode에서 가져옵니다.
ProductCodes.Type entity.entity.asset.attribute.labels.key=instances_set_product_codes_type, entity.entity.asset.attribute.labels.value 값은 Instances.ProductCodes.Type에서 가져옵니다.
RamdiskID entity.entity.asset.attribute.labels.key=instances_set_ramdisk_id, entity.entity.asset.attribute.labels.value 값은 Instances.RamdiskID에서 가져옵니다.
Reason entity.entity.asset.attribute.labels.key=instances_set_reason, entity.entity.asset.attribute.labels.value 값은 Instances.Reason에서 가져옵니다.
ReservationID entity.additional.fields.key=reservation_id, entity.additional.fields.value.string_value 값은 ReservationID에서 가져옵니다.
RequesterID entity.additional.fields.key=requester_id, entity.additional.fields.value.string_value 값은 RequesterID에서 가져옵니다.
RootDeviceName entity.entity.asset.attribute.labels.key=instances_set_root_device_name, entity.entity.asset.attribute.labels.value 값은 Instances.RootDeviceName에서 가져옵니다.
RootDeviceType entity.entity.asset.attribute.labels.key=instances_set_root_device_type, entity.entity.asset.attribute.labels.value 값은 Instances.RootDeviceType에서 가져옵니다.
SourceDestCheck entity.entity.asset.attribute.labels.key=instances_set_source_dest_check, entity.entity.asset.attribute.labels.value 값은 Instances.SourceDestCheck에서 가져옵니다.
SpotInstanceRequestID entity.entity.asset.attribute.labels.key=instances_set_spot_instance_request_id, entity.entity.asset.attribute.labels.value 값은 Instances.SpotInstanceRequestID에서 가져옵니다.
SriovNetSupport entity.entity.asset.attribute.labels.key=instances_set_sriov_net_support, entity.entity.asset.attribute.labels.value 값은 Instances.SriovNetSupport에서 가져옵니다.
StateReason entity.entity.asset.attribute.labels.key=instances_set_state_reason_code, entity.entity.asset.attribute.labels.value 값은 Instances.StateReason에서 가져옵니다.
StateReason.Code entity.entity.asset.attribute.labels.key=instances_set_state_reason_code, entity.entity.asset.attribute.labels.value 값은 Instances.StateReason.Code에서 가져옵니다.
StateReason.Message entity.entity.asset.attribute.labels.key=instances_set_state_reason_message, entity.entity.asset.attribute.labels.value 값은 Instances.StateReason.Message에서 가져옵니다.
SubnetID entity.entity.resource_ancestors.product_object_id, entity.entity.resource_ancestors.resource_type=SUBNET 값은 Instances.SubnetID에서 가져옵니다.
TagSet.Key entity.entity.asset.attribute.labels.key 값은 Instances.TagSet.Key에서 가져옵니다.
TagSet.Value entity.entity.asset.attribute.labels.value 값은 Instances.TagSet.Value에서 가져옵니다.
TpmSupport entity.entity.asset.attribute.labels.key=instances_set_tpm_support, entity.entity.asset.attribute.labels.value 값은 Instances.TpmSupport에서 가져옵니다.
UsageOperation entity.entity.asset.attribute.labels.key=instances_set_usage_operation, entity.entity.asset.attribute.labels.value 값은 Instances.UsageOperation에서 가져옵니다.
UsageOperationUpdateTime entity.entity.asset.attribute.labels.key=instances_set_usage_operation_update_time, entity.entity.asset.attribute.labels.value 값은 Instances.UsageOperationUpdateTime에서 가져옵니다.
VirtualizationType entity.entity.asset.attribute.labels.key=instances_set_virtualization_type, entity.entity.asset.attribute.labels.value 값은 Instances.VirtualizationType에서 가져옵니다.
VpcID entity.entity.resource_ancestors.product_object_id, entity.entity.resource_ancestors.resource_type=VPC_NETWORK 값은 Instances.VpcID에서 가져옵니다.
collection_time entity.metadata.collected_timestamp 값은 원시 로그의 collection_time 필드에서 직접 가져옵니다. AMAZON_WEB_SERVICES로 하드코딩되었습니다. IMAGE, VOLUME, SUBNET, VPC_NETWORK, 인스턴스 프로필 ARN, 용량 예약 ARN, 탄력적 인터페이스 가속기 ARN, 라이선스 구성 ARN 리소스 유형의 경우 AMAZON_WEB_SERVICES으로 하드코딩됩니다. SERVER로 하드코딩되었습니다. Amazon EC2로 하드코딩되었습니다. AWS로 하드코딩되었습니다. Instances.Placement.HostID이 있고 비어 있지 않은 경우 ASSET로 하드코딩됩니다. Instances.Placement.HostID이 있고 비어 있지 않은 경우 EXECUTES로 하드코딩됩니다. 애셋으로 하드코딩됩니다.

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