스팟 플릿 생성 - Amazon Elastic Compute Cloud

스팟 플릿 생성

AWS Management Console에서 AMI와 원하는 총 대상 용량만 선택하면 스팟 플릿 요청을 빠르게 생성할 수 있습니다. Amazon EC2는 스팟 모범 사례를 따르며 요구 사항을 가장 잘 충족하는 플릿을 구성합니다. 자세한 내용은 스팟 플릿 요청을 빠르게 생성(콘솔) 단원을 참조하십시오. 그렇지 않으면 어떠한 기본 설정이든 수정할 수 있습니다. 자세한 내용은 정의된 파라미터를 사용하여 스팟 플릿 요청 생성(콘솔)AWS CLI를 사용하여 스팟 플릿 생성 단원을 참조하세요.

플릿에 온디맨드 인스턴스를 포함하려면 요청에서 시작 템플릿을 지정하고 원하는 온디맨드 용량을 지정해야 합니다.

플릿은 가용 용량이 있을 때 온디맨드 인스턴스를 시작하고, 최고 가격이 스팟 가격을 초과하고 가용 용량이 있을 때 스팟 인스턴스를 시작합니다.

플릿에 스팟 인스턴스가 포함되어 있고 유형이 maintain인 경우 Amazon EC2에서 스팟 인스턴스가 중단되어도 플릿 목표 용량을 유지하려고 합니다.

스팟 플릿 권한

사용자가 스팟 플릿을 생성하거나 관리하는 경우 필요한 권한을 부여해야 합니다.

Amazon EC2 콘솔을 사용하여 스팟 플릿을 생성하는 경우 AWSServiceRoleForEC2SpotFleetAWSServiceRoleForEC2Spot이라는 서비스 연결 역할 2개와 스팟 플릿에 사용자 대신 리소스를 요청, 시작, 종료 및 태깅할 수 있는 권한을 부여하는 aws-ec2-spot-fleet-tagging-role이라는 역할이 생성됩니다. AWS CLI 또는 API를 사용하는 경우 이러한 역할이 존재하는지 확인해야 합니다.

다음 지침에 따라 필요한 권한을 부여하고 역할을 생성합니다.

스팟 플릿의 사용자에게 권한 부여

스팟 플릿을 생성하거나 관리하는 사용자에게 필요한 권한을 부여해야 합니다.

스팟 플릿에 대한 정책 생성
  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

  2. 탐색 창에서 정책을 선택한 후 정책 생성을 선택합니다.

  3. 정책 생성 페이지에서 JSON을 선택하고 텍스트를 다음과 같이 바꿉니다.

    { "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "ec2:RunInstances", "ec2:CreateTags", "ec2:RequestSpotFleet", "ec2:ModifySpotFleetRequest", "ec2:CancelSpotFleetRequests", "ec2:DescribeSpotFleetRequests", "ec2:DescribeSpotFleetInstances", "ec2:DescribeSpotFleetRequestHistory" ], "Resource": "*" }, { "Effect": "Allow", "Action": "iam:PassRole", "Resource": "arn:aws:iam::*:role/aws-ec2-spot-fleet-tagging-role" }, { "Effect": "Allow", "Action": [ "iam:CreateServiceLinkedRole", "iam:ListRoles", "iam:ListInstanceProfiles" ], "Resource": "*" } ] }

    위의 예제 정책은 사용자에게 대부분의 스팟 플릿 사용 사례에 필요한 권한을 부여합니다. 사용자를 특정 API 작업으로 제한하려면 대신 해당 작업만 지정하세요.

    필수 EC2 및 IAM API

    다음 API가 정책에 포함되어야 합니다.

    • ec2:RunInstances - 스팟 플릿에서 인스턴스를 시작하는 데 필요합니다.

    • ec2:CreateTags - 스팟 플릿 요청, 인스턴스 또는 볼륨을 태깅하는 데 필요합니다.

    • iam:PassRole - 스팟 플릿 역할을 지정하는 데 필요합니다.

    • iam:CreateServiceLinkedRole - 서비스 연결 역할을 생성하는 데 필요합니다.

    • iam:ListRoles - 기존 IAM 역할을 열거하는 데 필요합니다.

    • iam:ListInstanceProfiles - 기존 인스턴스 프로파일을 열거하는 데 필요합니다.

    중요

    시작 사양 또는 시작 템플릿에서 IAM 인스턴스 프로파일에 대한 역할을 지정하는 경우, 사용자에게 역할을 서비스에 전달할 수 있는 권한을 부여해야 합니다. 이를 위해 IAM 정책에 "arn:aws:iam::*:role/IamInstanceProfile-role" 작업을 위한 iam:PassRole 리소스를 포함하세요. 자세한 내용은 IAM 사용 설명서에서 사용자에게 AWS 서비스 역할을 전달할 수 있는 권한 부여를 참조하세요.

    스팟 플릿 API

    필요에 따라 다음 스팟 플릿 API 작업을 정책에 추가합니다.

    • ec2:RequestSpotFleet

    • ec2:ModifySpotFleetRequest

    • ec2:CancelSpotFleetRequests

    • ec2:DescribeSpotFleetRequests

    • ec2:DescribeSpotFleetInstances

    • ec2:DescribeSpotFleetRequestHistory

    선택적 IAM API

    (선택 사항) 사용자가 IAM 콘솔을 사용하여 역할 또는 인스턴스 프로파일을 생성할 수 있도록 하려면 정책에 다음 작업을 추가해야 합니다.

    • iam:AddRoleToInstanceProfile

    • iam:AttachRolePolicy

    • iam:CreateInstanceProfile

    • iam:CreateRole

    • iam:GetRole

    • iam:ListPolicies

  4. 정책 검토를 선택합니다.

  5. 정책 검토 페이지에 정책 이름과 설명을 입력한 다음 정책 생성을 선택합니다.

  6. 액세스 권한을 제공하려면 사용자, 그룹 또는 역할에 권한을 추가하세요:

    • AWS IAM Identity Center의 사용자 및 그룹:

      권한 세트를 생성합니다. AWS IAM Identity Center 사용 설명서권한 세트 생성의 지침을 따릅니다.

    • 보안 인증 공급자를 통해 IAM에서 관리되는 사용자:

      ID 페더레이션을 위한 역할을 생성합니다. IAM 사용 설명서서드 파티 자격 증명 공급자의 역할 만들기(페더레이션)의 지침을 따릅니다.

    • IAM 사용자:

      • 사용자가 맡을 수 있는 역할을 생성합니다. IAM 사용 설명서에서 IAM 사용자의 역할 생성의 지침을 따릅니다.

      • (권장되지 않음)정책을 사용자에게 직접 연결하거나 사용자를 사용자 그룹에 추가합니다. IAM 사용 설명서에서 사용자(콘솔)에 권한 추가의 지침을 따르십시오.

스팟 플릿의 서비스 연결 역할

Amazon EC2는 다른 AWS 서비스를 자동으로 호출하는 데 필요한 권한에 서비스 연결 역할을 사용합니다. 서비스 연결 역할은 AWS 서비스에 직접 연결된 고유한 유형의 IAM 역할입니다. 연결된 서비스만 서비스 연결 역할을 담당할 수 있으므로 서비스 연결 역할은 AWS 서비스로 권한을 위임하는 안전한 방법을 제공합니다. 자세한 내용은 IAM 사용 설명서서비스 연결 역할을 참조하세요.

Amazon EC2는 AWSServiceRoleForEC2Spot이라는 이름의 서비스 연결 역할을 사용하여 사용자 대신 인스턴스를 시작하고 관리합니다.

중요

스팟 플릿에서 암호화된 AMI 또는 암호화된 Amazon EBS 스냅샷을 지정하는 경우 Amazon EC2에서 자동으로 인스턴스를 시작하려면 CMK를 사용할 권한을 AWSServiceRoleForEC2SpotFleet 역할에 부여해야 합니다. 자세한 내용은 암호화된 AMI 및 EBS 스냅샷에 사용할 CMK에 대한 액세스 권한 부여 섹션을 참조하세요.

AWSServiceRoleForEC2SpotFleet에서 부여된 권한

AWSServiceRoleForEC2SpotFleet 역할은 스팟 플릿에 사용자 대신 인스턴스를 요청, 시작 및 종료하고 태그를 지정할 수 있는 권한을 부여합니다. Amazon EC2는 이 서비스 연결 역할을 사용하여 다음 작업을 완료합니다.

  • ec2:RequestSpotInstances - 스팟 인스턴스 요청

  • ec2:RunInstances - 인스턴스 시작

  • ec2:TerminateInstances - 인스턴스 종료

  • ec2:DescribeImages - 인스턴스에 대한 Amazon Machine Image(AMI) 설명

  • ec2:DescribeInstanceStatus - 인스턴스 상태 설명

  • ec2:DescribeSubnets - 인스턴스의 서브넷 설명

  • ec2:CreateTags - 스팟 플릿 요청, 인스턴스 및 볼륨에 태그 추가

  • elasticloadbalancing:RegisterInstancesWithLoadBalancer - 지정된 로드 밸런서에 지정된 인스턴스 추가

  • elasticloadbalancing:RegisterTargets - 지정된 대상 그룹에 지정된 대상 등록

서비스 연결 역할 생성

대부분의 상황에서는 서비스 연결 역할을 수동으로 생성할 필요가 없습니다. 사용자가 콘솔을 사용하여 처음으로 스팟 플릿을 생성하면 Amazon EC2가 AWSServiceRoleForEC2SpotFleet 서비스 연결 역할을 생성합니다.

Amazon EC2가 이 서비스 연결 역할을 지원하기 시작한 2017년 10월 이전에 활성 스팟 플릿 요청을 보유한 경우 Amazon EC2에는 사용자의 AWS 계정에 AWSServiceRoleForEC2SpotFleet 역할이 이미 생성되어 있습니다. 자세한 내용은 IAM 사용 설명서에서 내 AWS 계정에 표시되는 새 역할을 참조하세요.

AWS CLI 또는 API를 사용하여 스팟 플릿을 생성하는 경우 먼저 이 역할이 있는지 확인해야 합니다.

콘솔을 사용하여 스팟 플릿에 대한 AWSServiceRoleForEC2SpotFleet 역할을 생성하려면 다음을 수행하세요.
  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

  2. 탐색 창에서 역할을 선택합니다.

  3. 역할 생성을 선택합니다.

  4. 신뢰할 수 있는 엔터티 선택(Select trusted entity) 페이지에서 다음을 수행합니다.

    1. 신뢰할 수 있는 엔터티 유형에서 AWS 서비스를 선택합니다.

    2. 사용 사례에서 서비스 또는 사용 사례EC2를 선택합니다.

    3. 사용 사례에서 EC2 - 스팟 플릿을 선택합니다.

      참고

      EC2 - 스팟 플릿 사용 사례는 필요한 IAM 권한으로 정책을 자동으로 생성하고 AWSEC2SpotFleetServiceRolePolicy를 역할 이름으로 제안합니다.

    4. Next(다음)를 선택합니다.

  5. 권한 추가 페이지에서 다음을 선택합니다.

  6. 이름 지정, 검토 및 생성 페이지에서 역할 생성을 선택합니다.

AWS CLI를 사용하여 스팟 플릿에 대한 AWSServiceRoleForEC2SpotFleet 역할을 생성하려면 다음을 수행하세요.

다음과 같이 create-service-linked-role 명령을 사용합니다.

aws iam create-service-linked-role --aws-service-name spotfleet.amazonaws.com

스팟 플릿이 더 이상 필요 없으면 AWSServiceRoleForEC2SpotFleet 역할을 삭제하는 것이 좋습니다. 계정에서 이 역할이 삭제된 후 콘솔을 사용하여 스팟 플릿을 요청하면 Amazon EC2가 다시 해당 역할을 생성합니다. 자세한 내용은 IAM 사용 설명서의 서비스에 연결 역할 삭제를 참조하십시오.

암호화된 AMI 및 EBS 스냅샷에 사용할 CMK에 대한 액세스 권한 부여

스팟 플릿 요청에서 암호화된 AMI 또는 암호화된 Amazon EBS 스냅샷을 지정하고 암호화에 고객 관리형 키를 사용하는 경우 Amazon EC2에서 자동으로 인스턴스를 시작하려면 CMK를 사용할 권한을 AWSServiceRoleForEC2SpotFleet 역할에 부여해야 합니다. 이렇게 하려면 다음 절차에 표시된 바와 같이 CMK에 권한을 추가해야 합니다.

권한을 제공할 때 권한 부여는 키 정책을 대체합니다. 자세한 내용은 AWS Key Management Service 개발자 안내서에서 권한 부여 사용AWS KMS의 키 정책 사용을 참조하세요.

CMK를 사용할 수 있도록 AWSServiceRoleForEC2SpotFleet 역할 권한을 부여하려면
  • create-grant 명령을 사용하여 CMK에 권한을 추가하고 허용된 작업을 수행할 수 있는 권한이 부여된 보안 주체(AWSServiceRoleForEC2SpotFleet 서비스 연결 역할)를 지정합니다. CMK는 CMK의 key-id 파라미터 및 ARN에 의해 지정됩니다. 보안 주체는 AWSServiceRoleForEC2SpotFleet 서비스 연결 역할의 grantee-principal 파라미터 및 ARN에 의해 지정됩니다.

    aws kms create-grant \ --region us-east-1 \ --key-id arn:aws:kms:us-east-1:444455556666:key/1234abcd-12ab-34cd-56ef-1234567890ab \ --grantee-principal arn:aws:iam::111122223333:role/AWSServiceRoleForEC2SpotFleet \ --operations "Decrypt" "Encrypt" "GenerateDataKey" "GenerateDataKeyWithoutPlaintext" "CreateGrant" "DescribeKey" "ReEncryptFrom" "ReEncryptTo"

스팟 인스턴스에 대한 서비스 연결 역할

Amazon EC2는 AWSServiceRoleForEC2Spot이라는 이름의 서비스 연결 역할을 사용하여 사용자 대신 스팟 인스턴스를 시작하고 관리합니다. 자세한 내용은 스팟 인스턴스 요청에 대한 서비스 연결 역할 섹션을 참조하세요.

스팟 플릿 태깅을 위한 IAM 역할

aws-ec2-spot-fleet-tagging-role IAM 역할은 스팟 플릿 요청, 인스턴스 및 볼륨에 태깅할 수 있는 권한을 스팟 플릿에 부여합니다. 자세한 내용은 신규 또는 기존 스팟 플릿 요청과 이를 통해 시작되는 인스턴스 및 볼륨 태그 지정 단원을 참조하십시오.

중요

플릿의 인스턴스를 태깅하고 목표 용량을 유지하기로 선택하면(스팟 플릿 요청은 maintain 유형) 사용자 설정 권한 차이로 인해 IamFleetRole은 플릿에서 인스턴스의 태그 지정 동작이 일치하지 않을 수 있습니다. IamFleetRoleCreateTags 권한이 없으면 플릿에서 시작한 일부 인스턴스에 태그가 지정되지 않을 수 있습니다. 이러한 불일치를 수정하는 동안 플릿에서 시작한 모든 인스턴스에 태그가 지정되도록 하려면 aws-ec2-spot-fleet-tagging-roleIamFleetRole 역할을 사용하는 것이 좋습니다. 또는 기존 역할을 사용하려면 AmazonEC2SpotFleetTaggingRole AWS 관리형 정책을 기존 역할에 연결합니다. 그렇지 않으면 기존 정책에 CreateTags 권한을 수동으로 추가해야 합니다.

스팟 플릿 태깅을 위한 IAM 역할을 생성하려면
  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

  2. 탐색 창에서 역할을 선택합니다.

  3. 역할 생성을 선택합니다.

  4. 신뢰할 수 있는 엔터티 선택 페이지의 신뢰할 수 있는 엔터티 유형(Trusted entity type) 아래에서 서비스(AWS service)를 선택합니다.

  5. 사용 사례(Use case)기타 AWS 서비스 사용 사례(Use cases for other services)에서 EC2를 선택한 다음 EC2 - 스팟 플릿 태깅(EC2 - Spot Fleet Tagging)을 선택합니다.

  6. Next(다음)를 선택합니다.

  7. 권한 추가 페이지에서 다음을 선택합니다.

  8. 이름, 검토 및 생성 페이지에서 역할 이름(Role name)에서 역할 이름을 입력합니다(예: aws-ec2-spot-fleet-tagging-role).

  9. 페이지에서 정보를 검토한 다음 역할 생성(Create role)을 선택합니다.

교차 서비스 혼동된 대리인 방지

혼동된 대리자 문제는 작업을 수행할 권한이 없는 엔터티가 권한이 더 많은 엔터티에 작업을 수행하도록 강요할 수 있는 보안 문제입니다. 리소스에 다른 서비스를 제공하는 스팟 플릿 권한을 제한하려면 aws-ec2-spot-fleet-tagging-role 신뢰 정책에서 aws:SourceArnaws:SourceAccount 글로벌 조건 컨텍스트 키를 사용하는 것이 좋습니다.

aws:SourceArn 및 aws:SourceAccount 조건 키 aws-ec2-spot-fleet-tagging-role 신뢰 정책 추가
  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

  2. 탐색 창에서 역할을 선택합니다.

  3. 이전에 만든 aws-ec2-spot-fleet-tagging-role을 찾아 링크를 선택합니다(확인란 아님).

  4. 요약(Summary)에서 신뢰 관계(Trust relationships) 탭을 선택한 후 신뢰 정책 편집(Edit trust policy)을 선택합니다.

  5. JSON 문에 혼동된 대리자 문제(confused deputy problem)를 방지하는 aws:SourceAccountaws:SourceArn 전역 조건 컨텍스트 키 등의 Condition 요소를 추가합니다.

    "Condition": { "ArnLike": { "aws:SourceArn": "arn:aws:ec2:us-east-1:account_id:spot-fleet-request/sfr-*" }, "StringEquals": { "aws:SourceAccount": "account_id" }
    참고

    aws:SourceArn 값에 계정 ID가 포함되고 두 전역 조건 컨텍스트 키를 사용하는 경우, aws:SourceAccount 값 및 aws:SourceArn 값의 계정은 동일한 정책 문에서 사용될 경우 반드시 같은 계정 ID를 사용해야 합니다.

    최종 신뢰 정책은 다음과 같습니다.

    { "Version": "2012-10-17", "Statement": { "Sid": "ConfusedDeputyPreventionExamplePolicy", "Effect": "Allow", "Principal": { "Service": "spotfleet.amazonaws.com" }, "Action": "sts:AssumeRole", "Condition": { "ArnLike": { "aws:SourceArn": "arn:aws:ec2:us-east-1:account_id:spot-fleet-request/sfr-*" }, "StringEquals": { "aws:SourceAccount": "account_id" } } } }
  6. 정책 업데이트(Update policy)를 선택합니다.

다음 표에는 다양한 정도의 특정성을 가진 aws-ec2-spot-fleet-tagging-role 범위를 제한하기 위해 aws:SourceArn에 대한 잠재적 값을 제공합니다.

API 작업 호출된 서비스 범위 aws:SourceArn
RequestSpotFleet AWS STS (AssumeRole) 지정된 계정에서 스팟 플릿 요청에 대해 aws-ec2-spot-fleet-tagging-roleAssumeRole 기능을 제한합니다. arn:aws:ec2:*:123456789012:spot-fleet-request/sfr-*
RequestSpotFleet AWS STS (AssumeRole) 지정된 계정 및 지정된 리전에서 스팟 플릿 요청에 대해 aws-ec2-spot-fleet-tagging-roleAssumeRole 기능을 제한합니다. 이 역할은 다른 리전에서는 사용할 수 없습니다. arn:aws:ec2:us-east-1:123456789012:spot-fleet-request/sfr-*
RequestSpotFleet AWS STS (AssumeRole) 플릿 sfr-11111111-1111-1111-1111-111111111111에 영향을 미치는 작업에 대해서만 aws-ec2-spot-fleet-tagging-roleAssumeRole 기능을 제한합니다. 이 역할은 다른 스팟 플릿에서는 사용하지 못할 수 있습니다. 또한 이 역할은 요청 스팟 플릿을 통해 새로운 스팟 플릿을 시작하는 데 사용할 수 없습니다. arn:aws:ec2:us-east-1:123456789012:spot-fleet-request/sfr-11111111-1111-1111-1111-111111111111

스팟 플릿 요청을 빠르게 생성(콘솔)

다음 단계에 따라 빠르게 스팟 플릿 요청을 생성합니다.

권장되는 설정을 사용하여 스팟 플릿 요청을 생성하려면(콘솔)
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.

  2. 탐색 창에서 스팟 요청을 선택합니다.

  3. 스팟을 처음 사용하는 경우 시작 페이지가 표시되면 시작하기를 선택합니다. 그렇지 않다면 스팟 인스턴스 요청을 선택합니다.

  4. 시작 파라미터(Launch parameters) 아래에서 시작 파라미터 수동 구성(Manually configure launch parameters)을 선택합니다.

  5. AMI에서 AMI를 선택합니다.

  6. 목표 용량(Target capacity)총 목표 용량(Total target capacity)에 요청할 단위 수를 지정합니다. 단위 유형에서 인스턴스, vCPU 또는 메모리(GiB)를 선택할 수 있습니다.

  7. 플릿 요청 한눈에 보기(Your fleet request at a glance)에서 플릿 구성을 검토하고 시작(Launch)을 선택합니다.

정의된 파라미터를 사용하여 스팟 플릿 요청 생성(콘솔)

정의한 파라미터를 사용하여 스팟 플릿을 생성할 수 있습니다.

정의된 파라미터를 사용하여 스팟 플릿 요청을 생성하려면(콘솔)
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.

  2. 탐색 창에서 스팟 요청을 선택합니다.

  3. 스팟을 처음 사용하는 경우 시작 페이지가 표시되면 시작하기를 선택합니다. 그렇지 않다면 스팟 인스턴스 요청을 선택합니다.

  4. 시작 파라미터의 경우 다음과 같이 시작 파라미터를 수동으로 구성하거나 시작 템플릿을 사용할 수 있습니다.

    1. [수동 구성] Amazon EC2 콘솔에서 시작 파라미터를 정의하려면 시작 파라미터 수동 구성을 선택하고 다음을 수행합니다.

      1. AMI의 경우 AWS가 제공하는 기본 AMI 중 하나를 선택하거나 AMI 검색(Search for AMI)을 선택하여 사용자 커뮤니티, AWS Marketplace 또는 자체 AMI를 사용합니다.

        참고

        시작 파라미터에 지정된 AMI가 등록 취소되거나 비활성화된 경우 AMI에서 새 인스턴스를 시작할 수 없습니다. 목표 용량을 유지하도록 설정된 플릿의 경우 목표 용량이 유지되지 않습니다.

      2. (선택 사항) 키 페어 이름에서 기존 키 페어를 선택하거나 새로 생성합니다.

        [기존 키 페어] 키 페어를 선택합니다.

        [새 키 페어] 새 키 페어 생성을 선택하여 키 페어 페이지로 이동합니다. 마친 후에 스팟 요청(Spot Requests) 페이지로 돌아가고 목록을 새로 고칩니다.

      3. (선택 사항) 추가 시작 파라미터(Additional launch parameters)를 확장하고 다음을 수행합니다.

        1. (선택 사항) Amazon EBS 최적화를 사용하려면 EBS 최적화(EBS-optimized)에서 EBS 최적 인스턴스 시작(Launch EBS-optimized instances)을 선택합니다.

        2. (선택 사항) 인스턴스에 대해 임시 블록 스토리지를 추가하려면 인스턴스 스토어에 대해 시작 시 연결을 선택합니다.

        3. (선택 사항) 스토리지를 추가하려면 새로운 볼륨 추가(Add new volume)를 선택하고 인스턴스 유형에 따라 추가 인스턴스 스토어 볼륨이나 Amazon EBS 볼륨을 지정합니다.

        4. (선택 사항) 기본적으로 인스턴스에 대해 기본 모니터링 기능이 활성화됩니다. 세부 모니터링을 사용하려면 모니터링(Monitoring)에서 CloudWatch 세부 모니터링 활성화(Enable CloudWatch detailed monitoring)를 선택합니다.

        5. (선택 사항) 전용 스팟 인스턴스를 실행하려면 [테넌시(Tenancy)]에서 전용 - 전용 인스턴스 실행(Dedicated - run a dedicated instance)]을 선택합니다.

        6. (선택 사항) 보안 그룹에 대해 하나 이상의 보안 그룹을 선택하거나 보안 그룹을 생성합니다.

          [기존 보안 그룹] 하나 이상의 보안 그룹을 선택합니다.

          [새 보안 그룹] 새 보안 그룹 생성(Create new security group)을 선택하여 보안 그룹(Security Groups) 페이지로 이동합니다. 마친 후에 스팟 요청(Spot Requests) 페이지로 돌아가고 목록을 새로 고칩니다.

        7. (선택 사항) 인터넷에서 인스턴스에 연결할 수 있도록 하려면 IPv4 퍼블릭 IP 자동 할당에 대해 활성화를 선택합니다.

        8. (선택 사항) IAM 역할로 스팟 인스턴스를 시작하려면 IAM 인스턴스 프로파일에서 역할을 선택합니다.

        9. (선택 사항) 시작 스크립트를 실행하려면 해당 스크립트를 사용자 데이터에 복사합니다.

        10. (선택 사항) 태그를 추가하려면 태그 생성(Create tag)을 선택하고 해당 태그에 대한 키와 값을 입력한 다음 생성(Create)을 선택합니다. 각 태그에 대해 반복합니다.

          각 태그에서 인스턴스와 스팟 플릿 요청에 같은 태그를 사용하여 태깅하려면 인스턴스(Instance)플릿(Fleet)이 모두 선택되어 있는지 확인합니다. 플릿에서 시작한 인스턴스만 태깅하려면 플릿(Fleet)을 선택 취소합니다. 스팟 플릿 요청만 태깅하려면 인스턴스(Instance) 선택을 취소합니다.

    2. [시작 템플릿] 시작 템플릿에서 생성한 구성을 사용하려면 시작 템플릿 사용을 선택하고, 시작 템플릿에서 시작 템플릿을 선택합니다.

      참고

      스팟 플릿에서 온디맨드 용량을 사용하려면 시작 템플릿을 지정해야 합니다.

  5. (선택 사항) 추가 요청 세부 정보(Additional request details)에서 다음을 수행합니다.

    1. 추가 요청 세부 정보를 검토합니다. 변경하려면 기본값 적용(Apply defaults)의 선택을 취소합니다.

    2. (선택 사항) IAM 플릿 역할(IAM fleet role)에서 기본 역할을 사용하거나 다른 역할을 선택할 수 있습니다. 역할을 변경한 후 기본 역할을 사용하려면 기본 역할 사용을 선택합니다.

    3. (선택 사항) 특정 기간 동안만 유효한 요청을 생성하려면 요청 유효 시작 시간요청 유효 종료 시간(Request valid until)을 편집합니다.

    4. (선택 사항) 기본적으로 스팟 플릿 요청이 만료되면 Amazon EC2에서 스팟 인스턴스를 종료합니다. 요청 만료 후에도 계속 실행하려면 요청 만료 시 인스턴스 종료(Terminate the instances when the request expires)를 선택 취소합니다.

    5. (선택 사항) 로드 밸런서에 스팟 인스턴스를 등록하려면 하나 이상의 로드 밸런서에서 트래픽 수신을 선택하고 하나 이상의 Classic Load Balancer나 대상 그룹을 선택합니다.

  6. 목표 용량(Target capacity)에서 다음을 수행합니다.

    1. 총 목표 용량(Total target capacity)에서 요청할 단위 수를 지정합니다. 단위 유형에서 인스턴스(Instances), vCPU(vCPUs) 또는 메모리(MiB)(Memory (MiB))를 선택할 수 있습니다. 나중에 용량을 추가할 수 있도록 목표 용량을 0으로 지정하려면 목표 용량 유지를 선택해야 합니다.

    2. (선택 사항) 온디맨드 기반 용량 포함(Include On-Demand base capacity)에서 요청할 온디맨드 단위 수를 지정합니다. 이 수는 [총 목표 용량(Total target capacity)]보다 작아야 합니다. Amazon EC2는 차이를 계산하고 스팟 단위에 요청할 차이를 할당합니다.

      중요

      선택적 온디맨드 용량을 지정하려면 먼저 시작 템플릿을 선택해야 합니다.

    3. (선택 사항) 기본적으로 Amazon EC2는 스팟 인스턴스가 중단되면 스팟 인스턴스를 종료합니다. 목표 용량을 유지하려면 목표 용량 유지(Maintain target capacity)를 선택합니다. 그런 다음, 스팟 인스턴스가 중단되면 Amazon EC2는 해당 스팟 인스턴스를 종료하거나 중지하거나 최대 절전 모드로 전환합니다. 이를 위해 인터럽트 방식에서 해당 옵션을 선택합니다.

      참고

      시작 파라미터에 지정된 AMI가 등록 취소되거나 비활성화된 경우 AMI에서 새 인스턴스를 시작할 수 없습니다. 이 경우 목표 용량을 유지하도록 설정된 플릿의 목표 용량이 유지되지 않습니다.

    4. (선택 사항) 플릿의 기존 스팟 인스턴스에 대해 인스턴스 재분배 알림이 생성될 때 스팟 플릿에서 대체 스팟 인스턴스를 시작할 수 있도록 하려면 용량 재분배(Capacity rebalance)를 선택한 다음 인스턴스 대체 전략을 선택합니다. 종료 전 시작을 선택하는 경우 Amazon EC2에서 이전 인스턴스를 종료하기 전의 지연 시간(초)을 지정합니다. 자세한 내용은 EC2 플릿 및 스팟 플릿의 용량 리밸런싱을 사용하여 위험이 있는 스팟 인스턴스 교체 단원을 참조하십시오.

    5. (선택 사항) 플릿의 모든 스팟 인스턴스에 대해 시간당 지불하는 금액을 관리하려면 스팟 인스턴스의 최대 비용 설정(Set maximum cost for Spot Instances)을 선택한 다음 시간당 지불할 최대 총 금액을 입력합니다. 최대 총 금액에 도달하면 스팟 플릿은 목표 용량을 충족하지 않은 경우에도 스팟 인스턴스 시작을 중지합니다. 자세한 내용은 EC2 플릿 또는 스팟 플릿에 지출 한도 설정 단원을 참조하십시오.

  7. 네트워크(Network)에서 다음을 수행합니다.

    1. 네트워크에서 기존 VPC를 선택하거나 새로 생성합니다.

      [기존 VPC] VPC를 선택합니다.

      [새 VPC] Amazon VPC 콘솔로 이동하려면 새 VPC 생성을 선택합니다. 완료되면 이 화면으로 돌아와 목록을 새로 고칩니다.

    2. (선택 사항) 가용 영역의 경우 Amazon EC2에서 스팟 인스턴스에 대한 가용 영역을 자동으로 선택하도록 하거나 가용 영역을 하나 이상 지정합니다.

      가용 영역에 두 개 이상의 서브넷이 있는 경우 서브넷에서 알맞은 서브넷을 선택합니다. 서브넷을 추가하려면 새 서브넷 생성을 선택하여 Amazon VPC 콘솔로 이동합니다. 완료되면 이 화면으로 돌아와 목록을 새로 고칩니다.

  8. 인스턴스 유형 요구 사항(Instance type requirements)에서 인스턴스 속성을 지정하고 Amazon EC2가 해당 속성으로 인스턴스 유형을 식별하도록 하거나 인스턴스 목록을 지정할 수 있습니다. 자세한 내용은 EC2 플릿 또는 스팟 플릿의 인스턴스 유형 선택에 대한 속성 지정 단원을 참조하십시오.

    1. 컴퓨팅 요구 사항에 맞는 인스턴스 속성 지정(Specify instance attributes that match your compute requirements)을 선택하는 경우 다음과 같이 인스턴스 속성을 지정합니다.

      1. vCPU(vCPUs)에 원하는 최소 및 최대 vCPU 수를 입력합니다. 무한을 지정하려면 최소 없음, 최대 없음 또는 두 가지 모두를 선택합니다.

      2. 메모리(GiB)(Memory (GiB))에 원하는 최소 및 최대 메모리 양을 입력합니다. 무한을 지정하려면 최소 없음, 최대 없음 또는 두 가지 모두를 선택합니다.

      3. (선택 사항) 추가 인스턴스 속성에서 필요에 따라 하나 이상의 속성을 지정하여 컴퓨팅 요구 사항을 더 자세히 표현할 수 있습니다. 각 추가 속성은 요청에 추가 제약 조건을 추가합니다. 추가 속성을 생략할 수 있으며 생략 시 기본값이 사용됩니다. 각 속성과 기본값에 대한 설명은 Amazon EC2 Command Line Reference(Amazon EC2 명령줄 레퍼런스)의 get-spot-placement-scores를 참조하세요.

      4. (선택 사항) 지정한 속성을 가진 인스턴스 유형을 보려면 일치하는 인스턴스 유형 미리 보기(Preview matching instance types)를 확장합니다. 요청에 사용되는 인스턴스 유형을 제외하려면 인스턴스를 선택한 다음 선택한 인스턴스 유형 제외(Exclude selected instance types)를 선택합니다.

    2. 수동으로 인스턴스 유형 선택(Manually select instance types)을 선택하는 경우 스팟 플릿은 기본 인스턴스 유형 목록을 제공합니다. 인스턴스 유형을 더 많이 선택하려면 인스턴스 유형 추가(Add instance types)를 선택하고 요청에 사용할 인스턴스 유형을 선택한 다음 선택(Select)을 선택합니다. 인스턴스 유형을 삭제하려면 인스턴스 유형을 선택하고 삭제(Delete)를 선택합니다.

  9. 할당 전략의 경우 필요에 맞는 스팟 할당 전략과 온디맨드 할당 전략을 선택합니다. 자세한 내용은 할당 전략을 사용하여 EC2 플릿 또는 스팟 플릿이 스팟 및 온디맨드 용량을 충족하는 방법 결정 단원을 참조하십시오.

  10. 플릿 요청 한눈에 보기(Your fleet request at a glance)에서 플릿 구성을 검토하고 필요한 경우 조정합니다.

  11. (선택 사항) AWS CLI용 시작 구성의 복사본을 다운로드하려면 JSON 구성을 선택합니다.

  12. 스팟 플릿을 시작할 준비가 되면 시작을 선택합니다.

    스팟 플릿 요청 유형은 fleet입니다. 요청이 이행되면 instance 유형의 요청이 추가되며, 그 상태는 active이고 상황은 fulfilled입니다.

AWS CLI를 사용하여 스팟 플릿 생성

AWS CLI를 사용하여 스팟 플릿 요청 생성

request-spot-fleet 명령을 사용하여 스팟 플릿 요청을 생성합니다.

aws ec2 request-spot-fleet --spot-fleet-request-config file://config.json

구성 파일에 대한 예시는 예제 CLI 구성 스팟 플릿 섹션을 참조하세요.

다음은 예 출력입니다.

{ "SpotFleetRequestId": "sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE" }

비정상 스팟 인스턴스를 교체하는 스팟 플릿 생성

스팟 플릿은 2분마다 플릿의 스팟 인스턴스 상태를 확인합니다. 인스턴스의 상태는 healthy 또는 unhealthy입니다.

스팟 플릿은 Amazon EC2에서 제공하는 상태 확인을 사용하여 인스턴스의 상태를 판단합니다. 세 번의 연속 상태 확인에서 인스턴스 상태 또는 시스템 상태가 unhealthy인 경우, 해당 인스턴스의 상태는 impaired로 확인됩니다. 자세한 내용은 Amazon EC2 인스턴스 상태 확인 단원을 참조하십시오.

플릿을 구성하여 비정상 스팟 인스턴스를 교체할 수 있습니다. 상태 확인 교체를 사용하도록 설정한 이후 스팟 인스턴스는 unhealthy로 보고될 때 교체됩니다. 플릿은 비정상 스팟 인스턴스가 교체되는 동안 최대 몇 분간 목표 용량을 밑돌 수 있습니다.

요구 사항
  • 상태 확인 대체는 목표 용량을 유지하는스팟 집합(maintain 유형 플릿)에만 지원되며 일회성 스팟 집합(request 유형 플릿)에는 지원되지 않습니다.

  • 상태 확인 교체는 스팟 인스턴스에 대해서만 지원됩니다. 이 기능은 온디맨드 인스턴스에 대해 지원되지 않습니다.

  • 비정상 인스턴스를 생성할 경우에만 이를 교체하도록 스팟 플릿을 구성할 수 있습니다.

  • 사용자는 ec2:DescribeInstanceStatus 작업을 호출할 권한이 있는 경우에만 상태 확인 대체를 사용할 수 있습니다.

Console
비정상 스팟 인스턴스를 교체하도록 스팟 플릿을 구성하려면
  1. 정의된 파라미터를 사용하여 스팟 플릿 요청 생성(콘솔)의 스팟 플릿 생성 단계를 따릅니다.

  2. 비정상 스팟 인스턴스를 교체하도록 플릿을 구성하려면 추가 시작 파라미터를 확장하고 상태 확인에서 비정상 인스턴스 교체를 선택합니다. 이 옵션을 활성화하려면 먼저 대상 용량 유지를 선택해야 합니다.

AWS CLI
AWS CLI를 사용하여 비정상 스팟 인스턴스를 교체하도록 스팟 플릿 구성
  1. AWS CLI를 사용하여 스팟 플릿 생성의 스팟 플릿 생성 단계를 따릅니다.

  2. 비정상 스팟 인스턴스를 교체하도록 플릿을 구성하려면 ReplaceUnhealthyInstances에 대해 true를 입력합니다.