IAM(Identity and Access Management) 은 글로벌 서비스이다.

각 AWS Account에는 Root Account가 있다. 하지만 Root Account를 사용하기보다 User를 생성하고 권한을 부여받아서 사용하는 것을 권장한다.

아래 가이드라인 및 베스트 프랙티스를 참고하자!

해당 가이드라인에 따라 실습을 진행하고자 한다. 나눠서 포스팅을 할 예정인데 이번에는 IAM User/Group/Policy 생성하는 실습으로 작성할 것이다.

IAM Guidlines & Best Practices

  • AWS Account 설정을 제외하고는 Root Account를 사용하지 않는다.
  • 한 사람 당 하나의 User Account를 사용한다.
  • User를 Group에 할당하고 그 Group에 권한을 부여한다.
  • 강력한 패스워드 정책을 만든다.
  • MFA 사용!
  • AWS 서비스에 권한을 부여할 땐 Role 사용
  • CLI 또는 SDK를 사용할 땐 Access Key를 사용해라
  • Account의 권한을 감사할 땐 IAM 자격 증명 보고서(IAM Credential Reports)와 IAM 액세스 분석기(IAM Access Advisor) 사용 가능
  • 절대 IAM User와 Access Key를 공유하지 말 것!

IAM User 및 Group 생성

  1. IAM User를 먼저 생성한다.

    7041E3AF-5C2F-4DC3-A1A8-4D2E5B0659F1

  2. User를 Group에 추가하여 관리하는 것이 베스트 프랙티스이기 때문에 Group을 생성해 줄 것이다.

    941C653D-22B6-469D-98DC-F87EF0FB4F2E

  3. 일단 AdministratorAccess 권한을 가진 administrator 그룹을 만든다.

    CD47FFB0-8493-48EE-8640-526C86F34576

  4. 생성된 그룹을 선택해 준다.

    7B659CC7-7218-4CC7-92DC-67466DFC2EE0

  5. 설정 값을 검토하고 태그를 추가할 수 있다. 태그는 AWS 모든 리소스에 쓰이며 사용자의 접근을 추적, 조직, 제어할 수 있다.

    BEDFF5E5-C257-42AA-9B44-B88630B65A55

  6. User가 성공되었다는 메세지와 함께 로그인 정보를 csv 파일로 다운받아도 되고 안받아도 된다

    68DA2282-567C-4F7B-8598-03FB40FD912D

  7. IAM > 사용자 그룹(Groups)에서 확인해 보면 User engineer_yooadministrator Group에 소속된 걸 확인할 수 있다.

    Group administrator에는 AdministratorAccess 정책을 소유하고 있다.

    따라서, engineer_yooadministrator이라는 Group을 통하여 AdministratorAccess 권한을 승계받은 것이다.

    1A02BB58-255E-4276-8F36-EA0F96C94388

IAM Policy

먼저 Group에서 engineer_yoo를 지워서 권한을 없애고 시작하겠다!

그럼 아래와 같이 어느 서비스에도 접근을 할 수 없는 상태가 된다.

15EED97A-8BBF-4E8D-B78E-C14E1227AB24

(root 계정으로 로그인) 이 때 이 User에게 권한을 부여할 수 있는 방법은 아래와 같이 두 가지가 있다

Untitled

  1. 첫 번째는 권한을 추가하거나 (그룹 권한, 사용자의 권한 복사, 직접 정책 연결)

    Untitled 1

  2. 두 번째는 직접 정책을 생성해서 연결할 수 있다.

    Untitled 2

기존에 있는 IAMReadOnlyAccess 정책을 연결해 주었다.

Untitled 3

다시 engineer_yoo로 로그인해서 IAM에 들어와 보면 접근 가능함을 확인할 수 있다!

Untitled 4

다음 포스팅은..

  • Role Switch
  • IAM MFA
  • IAM Role
  • IAM 보안 도구

네 가지 더 남았다! 나머지 포스팅 다하고 느낀 점, 적용할 수 있는 사례, 목적 등을 고민해 봐야 겠다

Categories:

Updated: