06 Docker ECR
06 Docker ECR
1. EC2에 도커 환경구성
1. EC2에서 도커설치(정해진 명령어)
1
2
3
4
5
6
7
8
9
10
11
12
sudo apt-get update && \
sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common && \
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - && \
sudo apt-key fingerprint 0EBFCD88 && \
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" && \
sudo apt-get update && \
sudo apt-get install -y docker-ce && \
sudo usermod -aG docker ubuntu && \
newgrp docker && \
sudo curl -L "https://github.com/docker/compose/releases/download/2.27.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose && \
sudo chmod +x /usr/local/bin/docker-compose && \
sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
2. AWS ECR
1. AWS ECR
- 도커 이미지를 보관하는 저장소
- 로컬에서 만든 이미지나 CI 파이프라인에서 빌드된 이미지를 푸시해두고,
- EC2, ECS, EKS(쿠버네티스), 배치 작업 등이 그 이미지를 pull 해서 실행
2. Docker Hub와의 차이
- Docker Hub: 퍼블릭 중심, 계정 없이도 접근 가능
- ECR: AWS 계정 단위의 프라이빗 레지스트리, IAM으로 접근 제어
3. ECR 동작 흐름
- 개발자가 로컬에서 Dockerfile로 이미지 빌드
- AWS ECR에 로그인 (aws ecr get-login-password …)
- 이미지 태깅 (계정ID.dkr.ecr.region.amazonaws.com/리포지토리:태그)
- docker push 로 ECR에 업로드
- ECS/EKS/EC2가 해당 이미지를 pull 해서 컨테이너 실행
3. AWS ECR 활용
1. 로컬에 ECR 설치필요
- 윈도우/우분투/맥 상이함.
- 우분투 설치
1 2 3 4 5
$ sudo apt install unzip $ curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip" $ unzip awscliv2.zip $ sudo ./aws/install $ aws --version # 잘 출력된다면 정상 설치된 상태
2. IAM 생성
3. 컴퓨터 내 AWS ECR 설정(윈도우/우분투 동일)
1
2
3
4
5
$ aws configure
AWS Access Key ID [None]: <IAM에서 발급한 Key id>
AWS Secret Access Key [None]: <IAM에서 발급한 Secret Access Key>
Default region name [None]: ap-northeast-2 #서울 지역
Default output format [None]:
4. ECR 생성
5. ECR 이미지생성
6. 실행
- 실행은 기존 Dokcer에서 관리 및 사용하는 패턴 그대로 사용하게됨.
- 가장 초기에는 오류가 발생함.
- 그것은 기본 설정이 기존 dokcerHub로 접근하기떄문,
- 따라서 명령어 내역에서 ECR을 접근 후에 사용 필요
This post is licensed under CC BY 4.0 by the author.





