Amazon ECS 컨테이너 인스턴스 IAM 역할 - Amazon Elastic Container Service

Amazon ECS 컨테이너 인스턴스 IAM 역할

Amazon EC2와 외부 인스턴스를 포함한 Amazon ECS 컨테이너 인스턴스는 Amazon ECS 컨테이너 에이전트를 실행하며, 에이전트가 사용자에게 속한다는 것을 서비스에 알리기 위해 IAM 역할이 필요합니다. 컨테이너 인스턴스를 시작해 클러스터에 등록하기 전에 사용할 컨테이너 인스턴스의 IAM 역할을 생성해야 합니다.

중요

클러스터에 외부 인스턴스를 등록하는 경우 사용하는 IAM 역할에도 Systems Manager 권한이 필요합니다. 자세한 내용은 외부 인스턴스에 대한 필수 IAM 권한 섹션을 참조하세요.

Amazon ECS는 전체 Amazon ECS 기능 세트를 사용하는 데 필요한 권한이 포함된 AmazonEC2ContainerServiceforEC2Role 관리형 IAM 정책을 제공합니다. 이 관리형 정책은 IAM 연결에 연결하고, 컨테이너 인스턴스와 연결할 수 있습니다. 또는 사용할 사용자 지정 정책을 생성할 때 관리형 정책을 가이드로 사용할 수 있습니다. 컨테이너 인스턴스 역할은 Amazon ECS 컨테이너 에이전트 및 Docker 데몬이 사용자를 대신하여 AWS API를 호출하는 데 필요한 권한을 제공합니다. 관리형 정책에 대한 자세한 내용은 AmazonEC2ContainerServiceforEC2Role 섹션을 참조하세요.

Amazon ECS 컨테이너 인스턴스 IAM 역할 생성

중요

클러스터에 외부 인스턴스를 등록하는 경우 외부 인스턴스에 대한 필수 IAM 권한 섹션을 참조하세요.

Amazon ECS 콘솔 처음 실행을 완료하면 Amazon ECS 인스턴스 역할이 자동으로 생성됩니다. 다만 장래 기능 및 개선 사항이 도입될 때 Amazon ECS가 이에 대한 권한을 추가할 수 있도록 하려면 컨테이너 인스턴스의 관리형 IAM 정책을 수동으로 연결해야 합니다. 다음 절차를 사용하여 사용자의 계정에 이미 Amazon ECS 인스턴스 IAM 역할이 있는지 확인하고 필요하다면 관리형 IAM 정책을 연결할 수 있습니다.

IAM 콘솔에서 ecsInstanceRole을 확인하는 방법

  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

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

  3. 역할 목록에서 ecsInstanceRole을 검색합니다. 역할이 없으면 다음 섹션의 절차를 사용하여 역할을 생성합니다. 역할이 존재하지 않을 경우, 연결된 정책을 볼 역할을 선택합니다.

  4. 권한(Permissions) 탭을 선택합니다.

  5. 권한 정책 섹션에서 AmazonEC2ContainerServiceforEC2Role 관리형 정책 또는 이와 동등한 사용자 지정 정책이 역할에 연결되어 있는지 확인합니다. 정책이 연결된 경우, 컨테이너 인스턴스 역할이 적절히 구성된 것입니다. 그렇지 않다면 아래의 하위 단계에 따라 정책을 연결합니다.

    중요

    AmazonEC2ContainerServiceforEC2Role 관리형 정책이 컨테이너 인스턴스 IAM 역할에 연결되어야 합니다. 그렇지 않으면 AWS Management Console을 사용하여 클러스터를 생성할 때 오류가 표시됩니다.

    1. 정책 연결(Attach policies)을 선택합니다.

    2. 필터 정책 검색창에 AmazonEC2ContainerServiceforEC2Role을 입력해 연결에 사용할 수 있는 정책의 범위를 좁힙니다.

    3. AmazonEC2ContainerServiceforEC2Role 정책 왼쪽의 확인란을 선택하고 정책 연결(Attach policies)을 선택합니다.

  6. 신뢰 관계 탭을 선택하고 신뢰 관계 편집을 선택합니다.

  7. 신뢰 관계에 다음 정책이 포함되어 있는지 확인합니다. 신뢰 관계가 아래 정책과 일치하는 경우, 취소를 선택합니다. 신뢰 관계가 일치하지 않는 경우, 정책을 정책 문서 창에 복사하고 신뢰 정책 업데이트를 선택합니다.

    { "Version": "2008-10-17", "Statement": [ { "Sid": "", "Effect": "Allow", "Principal": { "Service": "ec2.amazonaws.com" }, "Action": "sts:AssumeRole" } ] }

컨테이너 인스턴스의 ecsInstanceRole IAM 역할을 생성하려면

  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

  2. 탐색 창에서 역할(Roles)을 선택한 후 역할 생성(Create role)을 선택합니다.

  3. AWS 서비스 역할 유형을 선택한 다음 Elastic Container Service를 선택합니다.

  4. Elastic Container Service에 대한 EC2 역할 사용 사례를 선택하고 다음: 권한(Next: Permissions)을 선택합니다.

  5. 권한 정책 연결 섹션에서 AmazonEC2ContainerServiceforEC2Role 정책을 선택했는지 확인하고 다음: 태그를 선택합니다.

    중요

    AmazonEC2ContainerServiceforEC2Role 관리형 정책이 컨테이너 인스턴스 IAM 역할에 연결되어야 합니다. 그렇지 않으면 AWS Management Console을 사용하여 클러스터를 생성할 때 오류가 표시됩니다.

  6. 태그 추가(Add tags)(선택 사항)에서 정책과 연결할 사용자 지정 태그를 지정한 다음 다음: 검토(Next: Review)를 선택합니다.

  7. 역할 이름ecsInstanceRole을 입력하고 필요한 경우 설명을 입력합니다.

  8. 역할 정보를 검토한 후 역할 생성을 선택하여 마칩니다.

컨테이너 인스턴스 IAM 역할에 Amazon S3 읽기 전용 액세스 추가

Amazon S3에서 구성 정보를 프라이빗 버킷에 저장하고 컨테이너 인스턴스 IAM 역할에 읽기 전용 액세스를 부여하면 시작 시점에 컨테이너 인스턴스 구성을 안전하고 편리하게 허용할 수 있습니다. ecs.config 파일의 사본을 프라이빗 버킷에 저장했다가 인스턴스가 시작할 때 Amazon EC2 사용자 데이터를 사용하여 AWS CLI를 설치하고 구성 정보를 /etc/ecs/ecs.config에 복사할 수 있습니다.

ecs.config 파일을 생성하여 Amazon S3에 저장하고 이 구성으로 인스턴스를 시작하는 자세한 방법은 Amazon S3에서 컨테이너 인스턴스 구성 저장 섹션을 참조하세요.

컨테이너 인스턴스 역할에 Amazon S3 읽기 전용 액세스를 허용하는 방법

  1. https://console.aws.amazon.com/iam/에서 IAM 콘솔을 엽니다.

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

  3. 컨테이너 인스턴스에서 사용할 IAM 역할을 선택합니다(이 역할의 제목은 ecsInstanceRole일 수 있음). 자세한 내용은 Amazon ECS 컨테이너 인스턴스 IAM 역할 섹션을 참조하세요.

  4. 권한(Permissions) 탭을 선택한 후 정책 연결(Attach policies)을 선택합니다.

  5. 정책 결과의 범위를 좁히려면 정책 연결 페이지에서 필터: 정책 유형 필드에 S3을 입력합니다.

  6. AmazonS3ReadOnlyAccess 정책 왼쪽의 확인란을 선택하고 정책 연결을 클릭합니다.

    참고

    이 정책으로 모든 Amazon S3 리소스에 대한 읽기 전용 액세스가 가능합니다. 보다 제한적인 버킷 정책의 예는 Amazon Simple Storage Service 개발자 안내서의 버킷 정책 예제 섹션을 참조하세요.