빠른 시작: Azure Portal을 사용하여 Azure 컨테이너 레지스트리 만들기
Azure Container Registry는 컨테이너 이미지 및 관련 아티팩트를 빌드, 저장 및 관리하기 위한 프라이빗 레지스트리 서비스입니다. 이 빠른 시작에서는 Azure Portal을 사용하여 Azure Container Registry 인스턴스를 만들었습니다. 그런 다음, Docker 명령을 사용하여 컨테이너 이미지를 레지스트리로 푸시하고, 마지막으로 레지스트리에서 이미지를 끌어와서 실행합니다.
컨테이너 이미지를 사용하기 위해 레지스트리에 로그인하려면 이 빠른 시작에서 Azure CLI(버전 2.0.55 이상 권장)를 실행해야 합니다. az --version
을 실행하여 버전을 찾습니다. 설치 또는 업그레이드해야 하는 경우 Azure CLI 설치를 참조하세요.
또한 디먼이 실행 중인 상태에서 Docker를 로컬로 설치해야 합니다. Docker는 모든 Mac, Windows 또는 Linux 시스템에서 쉽게 Docker를 구성하는 패키지를 제공합니다.
Azure에 로그인
Azure Portal에 로그인합니다.
컨테이너 레지스트리 만들기
리소스 만들기>컨테이너>컨테이너 레지스트리를 선택합니다.
기본 탭에서 리소스 그룹 및 레지스트리 이름에 대한 값을 입력합니다. 레지스트리 이름은 Azure 내에서 고유해야 하며, 5-50자의 영숫자만 포함해야 합니다. 이 빠른 시작에서는 이름이 지정된 myResourceGroup
위치에 새 리소스 그룹을 West US
만들고 SKU의 경우 '기본'을 선택합니다.
나머지 설정에 기본값을 적용합니다. 그런 다음, 검토 + 생성를 선택합니다. 설정을 검토한 후 만들기를 선택합니다.
팁
이 빠른 시작에서는 Azure Container Registry에 대해 학습하는 개발자를 위한 비용 최적화 옵션인 기본 레지스트리를 만듭니다. 스토리지 및 이미지 처리량을 늘리려면 다른 계층을 선택하고 프라이빗 엔드포인트를 사용하는 연결과 같은 기능을 선택합니다. 사용 가능한 서비스 계층(SKU)에 대한 자세한 내용은 컨테이너 레지스트리 서비스 계층을 참조하세요.
배포 성공 메시지가 나타나면 포털에서 컨테이너 레지스트리를 선택합니다.
레지스트리 이름 및 Azure 클라우드에서 끝나는 azurecr.io
정규화된 이름인 로그인 서버의 값을 기록해 둡다. Docker를 사용하여 이미지를 밀어넣고 끌어올 때 다음 단계에서 이러한 값을 사용합니다.
레지스트리에 로그인
컨테이너 이미지를 푸시하고 풀하기 전에 레지스트리 인스턴스에 로그인해야 합니다. 로컬 머신에서 Azure CLI에 로그인한 다음, az acr login 명령을 실행합니다. Azure CLI를 사용하여 로그인할 때 레지스트리 리소스 이름만 지정합니다. 정규화된 로그인 서버 이름을 사용하지 마세요.
az acr login --name <registry-name>
예시:
az acr login --name mycontainerregistry
명령이 완료되면 반환 Login Succeeded
됩니다.
레지스트리에 이미지 푸시
Azure Container Registry에 이미지를 푸시하려면 먼저 이미지가 있어야 합니다. 로컬 컨테이너 이미지가 아직 없는 경우 다음 docker pull 명령을 실행하여 기존 퍼블릭 이미지를 끌어옵니다. 이 예제에서는 Microsoft Container Registry에서 이미지를 끌어 hello-world
오세요.
docker pull mcr.microsoft.com/hello-world
레지스트리에 이미지를 푸시하기 전에 레지스트리 로그인 서버의 정규화된 이름을 사용하여 태그를 지정해야 합니다. 로그인 서버 이름은 <registry-name>.azurecr.io(모두 소문자여야 함) 형식입니다(예: mycontainerregistry.azurecr.io).
docker tag 명령을 사용하여 이미지에 태그를 지정합니다. <login-server>
를 ACR 인스턴스의 로그인 서버 이름으로 바꿉니다.
docker tag mcr.microsoft.com/hello-world <login-server>/hello-world:v1
예시:
docker tag mcr.microsoft.com/hello-world mycontainerregistry.azurecr.io/hello-world:v1
마지막으로 Docker 푸시를 사용하여 이미지를 레지스트리 인스턴스에 푸시합니다. 레지스트리 인스턴스의 로그인 서버 이름으로 바꿉 <login-server>
습니다. 이 예제에서는 hello-world:v1
이미지를 포함하는 hello-world 리포지토리를 만듭니다.
docker push <login-server>/hello-world:v1
이미지를 컨테이너 레지스트리에 푸시한 후에는 로컬 Docker 환경에서 hello-world:v1
이미지를 제거합니다. (이 docker rmi 명령은 Azure 컨테이너 레지스트리의 hello-world 리포지토리에서 이미지를 제거하지 않습니다.)
docker rmi <login-server>/hello-world:v1
컨테이너 이미지 나열
레지스트리의 이미지를 나열하려면 포털에서 레지스트리로 이동하여 리포지토리를 선택한 다음, docker push
를 사용하여 만든 hello-world 리포지토리를 선택합니다.
hello-world 리포지토리를 선택하면 태그 아래에 태그가 v1
지정된 이미지가 표시됩니다.
레지스트리에서 이미지 실행
이제 docker run을 사용하여 컨테이너 레지스트리에서 hello-world:v1
컨테이너 이미지를 끌어와서 실행할 수 있습니다.
docker run <login-server>/hello-world:v1
예제 출력:
Unable to find image 'mycontainerregistry.azurecr.io/hello-world:v1' locally
v1: Pulling from hello-world
Digest: sha256:662dd8e65ef7ccf13f417962c2f77567d3b132f12c95909de6c85ac3c326a345
Status: Downloaded newer image for mycontainerregistry.azurecr.io/hello-world:v1
Hello from Docker!
This message shows that your installation appears to be working correctly.
[...]
리소스 정리
리소스를 클린 포털에서 myResourceGroup 리소스 그룹으로 이동합니다. 리소스 그룹이 로드되면 리소스 그룹 삭제를 클릭하여 리소스 그룹 , 컨테이너 레지스트리 및 거기에 저장된 컨테이너 이미지를 제거합니다.
다음 단계
이 빠른 시작에서는 Azure Portal을 사용하여 Azure Container Registry를 만들고, 컨테이너 이미지를 푸시하고, 레지스트리에서 이미지를 끌어와 실행했습니다. Azure Container Registry 자습서를 계속 진행하여 ACR에 대해 자세히 알아보세요.
피드백
https://aka.ms/ContentUserFeedback
출시 예정: 2024년 내내 콘텐츠에 대한 피드백 메커니즘으로 GitHub 문제를 단계적으로 폐지하고 이를 새로운 피드백 시스템으로 바꿀 예정입니다. 자세한 내용은 다음을 참조하세요.다음에 대한 사용자 의견 제출 및 보기