Azure에서 사용자 지정 컨테이너 실행
Azure App Service는 IIS에서 실행하는 ASP.NET 또는 Node.js와 같은 Windows에서 미리 정의된 애플리케이션 스택을 제공합니다. 그러나 미리 구성된 애플리케이션 스택은 운영 체제를 잠그고 낮은 수준의 액세스를 차단합니다. 사용자 지정 Windows 컨테이너에는 이러한 제한이 없으며 개발자가 컨테이너를 완전히 사용자 지정하고 컨테이너화된 애플리케이션에 Windows 기능에 대한 모든 권한을 부여할 수 있습니다.
이 빠른 시작에서는 Windows 이미지의 ASP.NET 앱을 Visual Studio에서 Azure Container Registry로 배포하는 방법을 보여 줍니다. Azure App Service의 사용자 지정 컨테이너에서 앱을 실행합니다.
이 빠른 시작을 완료하려면 다음이 필요합니다.
- Windows용 Docker 설치
- Windows 컨테이너를 실행하도록 Docker 전환
- ASP.NET 및 웹 개발 및 Azure 개발 워크로드가 있는 Visual Studio 2022를 설치합니다. Visual Studio 2022 Community에서 .NET Framework 프로젝트 및 항목 템플릿 구성 요소가 ASP.NET 및 웹 개발 워크로드와 함께 선택되어 있는지 확인합니다. Visual Studio 2022를 이미 설치한 경우 다음을 수행합니다.
- 도움말>업데이트 확인을 차례로 선택하여 Visual Studio에서 최신 업데이트를 설치합니다.
- 도구>도구 및 기능 가져오기를 차례로 선택하여 Visual Studio에서 워크로드를 추가합니다.
1 - ASP.NET 웹앱 만들기
다음 단계에 따라 ASP.NET 웹앱을 만듭니다.
Visual Studio를 연 다음, 새 프로젝트 만들기를 선택합니다.
새 프로젝트 만들기에서 C#용 ASP.NET 웹 애플리케이션(.NET Framework)을 찾아서 선택하고, 다음을 선택합니다.
새 프로젝트 구성의 프로젝트 이름 아래에서 애플리케이션 이름을 myfirstazurewebapp으로 지정합니다. 프레임워크 아래에서 .NET Framework 4.8을 선택한 다음, 만들기를 선택합니다.
모든 종류의 ASP.NET 웹앱을 Azure에 배포할 수 있습니다. 이 빠른 시작에서는 MVC 템플릿을 선택합니다.
인증 아래에서 없음을 선택합니다. 고급 아래에서 Docker 지원을 선택하고, HTTPS로 구성을 선택 취소합니다. 만들기를 실행합니다.
Dockerfile 파일이 자동으로 열리지 않으면 솔루션 탐색기에서 엽니다.
지원되는 부모 이미지가 필요합니다.
FROM
줄을 다음 코드로 바꾸고 파일을 저장하여 부모 이미지를 변경합니다.FROM mcr.microsoft.com/dotnet/framework/aspnet:4.8-windowsservercore-ltsc2019
Visual Studio 메뉴에서 디버그>디버깅하지 않고 시작을 차례로 선택하여 웹앱을 로컬로 실행합니다.
2 - Azure Container Registry에 게시
솔루션 탐색기에서 마우스 오른쪽 단추로 myfirstazurewebapp 프로젝트를 클릭하고 게시를 선택합니다.
대상에서 Docker Container Registry를 선택한 후 다음을 선택합니다.
특정 대상에서 Azure Container Registry를 선택한 후 다음을 선택합니다.
게시에서 올바른 구독이 선택되어 있는지 확인합니다. 컨테이너 레지스트리에서 + 단추를 선택하여 새 Azure Container Registry를 만듭니다.
새로 만들기에서 올바른 구독이 선택되어 있는지 확인합니다. 리소스 그룹에서 새로 만들기를 선택하고 이름으로 myResourceGroup을 입력한 다음 확인을 선택합니다. SKU 아래에서 기본을 선택합니다. 레지스트리 위치 아래에서 레지스트리의 위치를 선택한 다음, 만들기를 선택합니다.
게시의 Container Registry 아래에서 만든 레지스트리를 선택한 다음, 마침을 선택합니다.
배포가 완료될 때가지 기다립니다. 이제 게시 페이지에 리포지토리 이름이 표시됩니다. 복사 단추를 선택하여 나중에 사용할 리포지토리 이름을 복사합니다.
3 - Windows 사용자 지정 컨테이너 만들기
Azure Portal에 로그인합니다.
Azure Portal의 왼쪽 상단 모서리에서 리소스 만들기를 선택합니다.
인기 있는 서비스에서 웹앱 아래에 있는 만들기를 선택합니다.
웹앱 만들기에서 구독 및 리소스 그룹을 선택합니다. 필요한 경우 새 리소스 그룹을 만들 수 있습니다.
win-container-demo와 같은 앱 이름을 입력합니다. 게시에 Docker 컨테이너를, 운영 체제에 Windows를 선택합니다. 계속하려면 다음: Docker를 선택합니다.
이미지 원본에 대해 Docker Hub를 선택하고, 이미지 및 태그에 대해 Azure Container Registry에 게시에서 복사한 리포지토리 이름을 입력합니다.
웹 애플리케이션에 대한 사용자 지정 이미지가 Azure Container Registry 또는 다른 프라이빗 리포지토리와 같이 다른 곳에 있는 경우 여기에서 구성할 수 있습니다. 검토 + 만들기를 선택하여 계속 진행합니다.
모든 세부 정보를 확인한 다음 만들기를 선택하고 Azure에서 필요한 리소스를 만들 때까지 기다립니다.
4 - 사용자 지정 컨테이너 찾아보기
Azure 작업이 완료되면 알림 상자가 표시됩니다.
리소스로 이동을 클릭합니다.
이 리소스의 개요에서 URL 옆에 있는 링크를 따릅니다.
다음 페이지의 새 브라우저 페이지가 열립니다.
기본 ASP.NET 홈 페이지가 표시될 때까지 몇 분 정도 기다렸다가 다시 시도하세요.
축하합니다! Azure App Service에서 첫 번째 사용자 지정 Windows 컨테이너를 실행하고 있습니다.
5 - 컨테이너 시작 로그 보기
Windows 컨테이너를 로드하는 데 다소 시간이 걸릴 수 있습니다. 진행률을 보려면 <app_name>을 앱 이름으로 대체하여 다음 URL로 이동합니다.
https://<app_name>.scm.azurewebsites.net/api/logstream
스트리밍된 로그는 다음과 같이 표시됩니다.
2018-07-27T12:03:11 Welcome, you are now connected to log-streaming service.
27/07/2018 12:04:10.978 INFO - Site: win-container-demo - Start container succeeded. Container: facbf6cb214de86e58557a6d073396f640bbe2fdec88f8368695c8d1331fc94b
27/07/2018 12:04:16.767 INFO - Site: win-container-demo - Container start complete
27/07/2018 12:05:05.017 INFO - Site: win-container-demo - Container start complete
27/07/2018 12:05:05.020 INFO - Site: win-container-demo - Container started successfully
6 - 로컬로 업데이트 및 다시 배포
Visual Studio의 솔루션 탐색기에서 보기>홈>Index.cshtml을 차례로 엽니다.
위쪽 가까이에
<div class="jumbotron">
HTML 태그를 찾아서 전체 요소를 다음 코드로 바꿉니다.<div class="jumbotron"> <h1>ASP.NET in Azure!</h1> <p class="lead">This is a simple app that we've built that demonstrates how to deploy a .NET app to Azure App Service.</p> </div>
Azure에 다시 배포하려면 솔루션 탐색기에서 마우스 오른쪽 단추로 myfirstazurewebapp 프로젝트를 클릭하고 게시를 선택합니다.
게시 페이지에서 게시를 선택하고 게시가 완료될 때까지 기다립니다.
App Service가 Docker 허브에서 새 이미지를 끌어오도록 하려면, 앱을 다시 시작합니다. 포털의 앱 페이지로 돌아가서 다시 시작>예를 클릭합니다.
사용자 지정 컨테이너를 다시 찾습니다. 웹 페이지를 새로 고치면 처음에는 앱이 '시작' 페이지로 돌아간 다음 몇 분 후에 업데이트된 웹 페이지가 표시됩니다.
7 - 리소스 정리
이전 단계에서는 리소스 그룹에서 Azure 리소스를 만들었습니다. 나중에 이러한 리소스가 필요하지 않은 경우에 리소스 그룹을 삭제하여 삭제할 수 있습니다.
Azure Portal 메뉴 또는 홈 페이지에서 리소스 그룹을 선택합니다. 그런 다음, 리소스 그룹 페이지에서 myResourceGroup을 선택합니다.
myResourceGroup 페이지에서 나열된 리소스가 삭제하려는 리소스인지 확인합니다.
리소스 그룹 삭제를 선택하고, 텍스트 상자에서 myResourceGroup을 입력하여 확인한 다음, 삭제를 선택합니다.
다음 단계
Azure App Service on Linux는 .NET, PHP, Node.js 등과 같은 언어 지원을 통해 Linux에서 미리 정의된 애플리케이션 스택을 제공합니다. 사용자 지정 Docker 이미지를 사용하여 Azure에 아직 정의되지 않은 애플리케이션 스택에서 웹앱을 실행할 수도 있습니다. 이 빠른 시작에서는 ACR(Azure Container Registry)에서 App Service로 이미지를 배포하는 방법을 보여 줍니다.
참고 항목
서버리스 환경에서 컨테이너화된 애플리케이션을 실행하는 방법에 대한 자세한 내용은 Container Apps를 참조하세요.
이 빠른 시작을 완료하려면 다음이 필요합니다.
- Azure 계정
- Docker
- Visual Studio Code
- VS Code용 Azure App Service 확장. 이 확장을 사용하여 Azure PaaS(Platform as a Service)에서 Linux Web Apps를 만들고, 관리하고, 배포할 수 있습니다.
- VS Code용 Docker 확장. 이 확장을 사용하여 로컬 Docker 이미지 및 명령 관리를 간소화하고 빌드된 앱 이미지를 Azure에 배포할 수 있습니다.
1 - 컨테이너 레지스트리 만들기
이 빠른 시작에서는 Azure Container Registry를 선택한 레지스트리로 사용합니다. 다른 레지스트리도 자유롭게 사용할 수 있지만 단계는 약간 다를 수 있습니다.
빠른 시작: Azure Portal을 사용하여 프라이빗 컨테이너 레지스트리 만들기의 지침에 따라 컨테이너 레지스트리를 만듭니다.
Important
Azure 컨테이너 레지스트리를 만들 때 관리 사용자 옵션을 사용으로 설정해야 합니다. Azure Portal 레지스트리 페이지의 액세스 키 섹션에서 설정할 수도 있습니다. 이 설정은 App Service 액세스에 필요합니다. 관리 ID에 대한 내용은 ACR에서 배포 자습서를 참조하세요.
2 - 로그인
Visual Studio Code를 시작합니다.
작업 표시줄에서 Azure 로고를 선택하고 APP SERVICE 탐색기로 이동한 다음, Azure에 로그인을 선택하고 지침을 따릅니다.
아래쪽의 상태 표시줄에서 Azure 계정 메일 주소를 확인합니다. APP SERVICE 탐색기에 사용자의 구독이 표시되어야 합니다.
작업 표시줄에서 Docker 로고를 선택합니다. REGISTRIES 탐색기에서 만든 컨테이너 레지스트리가 나타나는지 확인합니다.
3 - 필수 구성 요소 확인
Docker가 설치되어 실행 중인지 확인합니다. 다음 명령은 실행 중인 경우 Docker 버전을 표시합니다.
docker --version
4 - 이미지 만들기 및 빌드
- Visual Studio Code에서 빈 폴더를 열고
Dockerfile
이라는 파일을 추가합니다. Dockerfile에서 원하는 언어 프레임워크를 기준으로 콘텐츠를 붙여넣습니다.
FROM mcr.microsoft.com/appsvc/dotnetcore:lts
ENV PORT 8080
EXPOSE 8080
ENV ASPNETCORE_URLS "http://*:${PORT}"
ENTRYPOINT ["dotnet", "/defaulthome/hostingstart/hostingstart.dll"]
이 Dockerfile에서 부모 이미지는 App Service의 기본 제공 .NET 컨테이너 중 하나입니다.
명령 팔레트를 열고 Docker Images: Build Image를 입력합니다. Enter를 입력하여 명령을 실행합니다.
이미지 태그 상자에서 원하는 태그를
<acr-name>.azurecr.io/<image-name>:<tag>
형식으로 지정합니다. 여기서<acr-name>
은 사용자가 만든 컨테이너 레지스트리의 이름입니다. Enter 키를 누릅니다.이미지 빌드가 완료되면 IMAGES 탐색기 위쪽에서 새로 고침을 클릭하여 이미지가 성공적으로 빌드되었는지 확인합니다.
5 - 컨테이너 레지스트리에 배포
작업 표시줄에서 Docker 아이콘을 클릭합니다. IMAGES 탐색기에서 빌드한 이미지를 찾습니다.
이미지를 확장하고, 원하는 태그를 마우스 오른쪽 단추로 클릭한 후, 푸시를 클릭합니다.
이미지 태그가
<acr-name>.azurecr.io
로 시작하는지 확인하고 Enter 키를 누릅니다.Visual Studio Code가 컨테이너 레지스트리에 이미지를 푸시하는 작업을 완료하면 REGISTRIES 탐색기의 맨 위에 있는 새로 고침을 클릭하여 이미지가 성공적으로 푸시되었는지 확인합니다.
6 - App Service에 배포
- REGISTRIES 탐색기에서 이미지를 확장하고 태그를 마우스 오른쪽 단추로 클릭한 다음 Azure App Service에 이미지 배포를 선택합니다.
- 표시되는 메시지에 따라 구독, 전역적으로 고유한 앱 이름, 리소스 그룹 및 App Service 요금제를 선택합니다. 가격 책정 계층으로 B1 기본을 선택하고 가까운 지역을 선택합니다.
배포 후에는 http://<app-name>.azurewebsites.net
에서 앱을 사용할 수 있습니다.
리소스 그룹은 Azure에 있는 모든 애플리케이션 리소스의 명명된 컬렉션입니다. 예를 들어 리소스 그룹에는 웹 사이트, 데이터베이스 및 Azure 함수에 대한 참조가 포함될 수 있습니다.
App Service 계획은 웹 사이트를 호스트하는 데 사용되는 물리적 리소스를 정의합니다. 이 빠른 시작에서는 Linux 인프라의 기본 호스팅 계획을 사용하므로, 사이트가 다른 웹 사이트와 함께 Linux 머신에 호스트됩니다. 기본 계획으로 시작하는 경우, Azure Portal을 사용하여 해당 웹 사이트만 머신에서만 실행되도록 강화할 수 있습니다. 가격 책정에 대해서는 App Service 가격을 참조하세요.
7 - 웹 사이트 찾아보기
출력 패널에 배포 작업의 상태가 표시됩니다. 작업이 완료되면 팝업 알림에서 사이트 열기를 선택하여 브라우저에서 사이트를 엽니다.
8 - 리소스 정리
이전 단계에서는 리소스 그룹에서 Azure 리소스를 만들었습니다. 나중에 이러한 리소스가 필요하지 않은 경우에 리소스 그룹을 삭제하여 삭제할 수 있습니다.
Azure Portal 메뉴 또는 홈 페이지에서 리소스 그룹을 선택합니다. 그런 다음, 리소스 그룹 페이지에서 myResourceGroup을 선택합니다.
myResourceGroup 페이지에서 나열된 리소스가 삭제하려는 리소스인지 확인합니다.
리소스 그룹 삭제를 선택하고, 텍스트 상자에서 myResourceGroup을 입력하여 확인한 다음, 삭제를 선택합니다.
다음 단계
축하합니다. 이 빠른 시작을 성공적으로 완료하셨습니다.
App Service 앱은 시작할 때마다 컨테이너 레지스트리에서 이미지를 가져옵니다. 이미지를 다시 빌드하는 경우 컨테이너 레지스트리에 푸시하기만 하면 앱이 다시 시작될 때 업데이트된 이미지를 가져옵니다. 업데이트된 이미지를 즉시 가져오도록 앱에 지시하려면 다시 시작합니다.
다른 Azure 확장:
- Azure Cosmos DB
- Azure Functions
- Azure CLI 도구
- Azure Resource Manager 도구
- Azure 도구 확장 팩에는 위의 확장이 모두 포함되어 있습니다.
Azure App Service on Linux는 .NET, PHP, Node.js 등과 같은 언어 지원을 통해 Linux에서 미리 정의된 애플리케이션 스택을 제공합니다. 사용자 지정 Docker 이미지를 사용하여 Azure에 아직 정의되지 않은 애플리케이션 스택에서 웹앱을 실행할 수도 있습니다. 이 빠른 시작에서는 이미지를 Azure Container Registry에서 Azure App Service로 배포하는 방법을 보여 줍니다.
참고 항목
서버리스 환경에서 컨테이너화된 애플리케이션을 실행하는 방법에 대한 자세한 내용은 Container Apps를 참조하세요.
이 빠른 시작을 완료하려면 다음이 필요합니다.
1 - 샘플 리포지토리 복제
다음 명령을 사용하여 .NET 6.0 샘플 앱을 복제합니다.
git clone https://github.com/Azure-Samples/dotnetcore-docs-hello-world.git
2 - Azure Container Registry에 이미지 푸시
복제된 리포지토리의 루트 폴더에 있는지 확인합니다. 이 리포지토리에는 Dockerfile.linux 파일이 포함되어 있습니다.
Azure CLI에 로그인합니다.
az login
Azure Container Registry에 로그인합니다.
az acr login -n <your_registry_name>
컨테이너 이미지를 빌드합니다. 이미지 이름을 dotnetcore-docs-hello-world-linux로 지정합니다.
docker build -f Dockerfile.linux -t <your_registry_name>.azurecr.io/dotnetcore-docs-hello-world-linux .
컨테이너 이미지를 Azure Container Registry에 푸시합니다.
docker push <your_registry_name>.azurecr.io/dotnetcore-docs-hello-world-linux:latest
참고 항목
Dockerfile은 내부적으로 포트 번호를 80으로 설정합니다. 컨테이너를 구성하는 방법에 대한 자세한 내용은 사용자 지정 컨테이너 구성을 참조하세요.
3 - Azure에 배포
Azure Portal에 로그인
Azure Portal에 로그인합니다.
Azure 리소스 만들기
검색에 앱 서비스를 입력합니다. 서비스 아래에서 App Services를 선택합니다.
App Services 페이지에서 + 만들기를 선택합니다.
기본 탭의 프로젝트 세부 정보 아래에서 올바른 구독이 선택되어 있는지 확인한 다음, 새 리소스 그룹 만들기를 선택합니다. 이름으로 myResourceGroup을 입력합니다.
인스턴스 세부 정보 아래에서 전역적으로 고유한 웹앱 이름을 입력하고, Docker 컨테이너를 선택합니다. 운영 체제에 대해 Linux를 선택합니다. 앱을 제공하려는 지역을 선택합니다.
App Service 요금제에서 새 App Service 요금제 만들기를 선택합니다. 이름으로 myAppServicePlan을 입력합니다. 무료 계층으로 변경하려면 크기 변경, 개발/테스트 탭, F1을 차례로 선택하고, 페이지 아래쪽에서 적용 단추를 선택합니다.
페이지 아래쪽에서 다음: Docker > 단추를 선택합니다.
Docker 탭의 옵션 아래에서 단일 컨테이너를 선택하고, 이미지 원본에 대해 Azure Container Registry를 선택합니다. Azure Container Registry 옵션 아래에서 다음 값을 설정합니다.
- 레지스트리: Azure Container Registry를 선택합니다.
- 이미지: dotnetcore-docs-hello-world-linux를 선택합니다.
- 태그: latest를 선택합니다.
페이지 아래쪽에서 검토 + 만들기 단추를 선택합니다.
유효성 검사를 실행한 후 페이지 아래쪽에서 생성하기 단추를 선택합니다.
배포가 완료되면 리소스로 이동을 선택합니다.
4 - 앱으로 이동
웹 브라우저에서 배포된 애플리케이션(URL: http://<app-name>.azurewebsites.net
)으로 이동합니다.
5 - 리소스 정리
이전 단계에서는 리소스 그룹에서 Azure 리소스를 만들었습니다. 나중에 이러한 리소스가 필요하지 않은 경우에 리소스 그룹을 삭제하여 삭제할 수 있습니다.
Azure Portal 메뉴 또는 홈 페이지에서 리소스 그룹을 선택합니다. 그런 다음, 리소스 그룹 페이지에서 myResourceGroup을 선택합니다.
myResourceGroup 페이지에서 나열된 리소스가 삭제하려는 리소스인지 확인합니다.
리소스 그룹 삭제를 선택하고, 텍스트 상자에서 myResourceGroup을 입력하여 확인한 다음, 삭제를 선택합니다.
다음 단계
축하합니다. 이 빠른 시작을 성공적으로 완료하셨습니다.
App Service 앱은 시작할 때마다 컨테이너 레지스트리에서 이미지를 가져옵니다. 이미지를 다시 빌드하는 경우 컨테이너 레지스트리에 푸시하기만 하면 앱이 다시 시작될 때 업데이트된 이미지를 가져옵니다. 업데이트된 이미지를 즉시 가져오도록 앱에 지시하려면 다시 시작합니다.
Azure App Service는 IIS에서 실행하는 ASP.NET 또는 Node.js와 같은 Windows에서 미리 정의된 애플리케이션 스택을 제공합니다. 그러나 미리 구성된 애플리케이션 스택은 운영 체제를 잠그고 낮은 수준의 액세스를 차단합니다. 사용자 지정 Windows 컨테이너에는 이러한 제한이 없으며 개발자가 컨테이너를 완전히 사용자 지정하고 컨테이너화된 애플리케이션에 Windows 기능에 대한 모든 권한을 부여할 수 있습니다.
이 빠른 시작에서는 Windows 이미지의 ASP.NET 앱을 Azure Container Registry에서 Azure App Service로 배포하는 방법을 보여 줍니다.
이 빠른 시작을 완료하려면 다음이 필요합니다.
1 - 샘플 리포지토리 복제
다음 명령을 사용하여 .NET 6.0 샘플 앱을 복제합니다.
git clone https://github.com/Azure-Samples/dotnetcore-docs-hello-world.git
2 - Azure Container Registry에 이미지 푸시
복제된 리포지토리의 루트 폴더에 있는지 확인합니다. 이 리포지토리에는 Dockerfile.windows 파일이 포함되어 있습니다. Windows Nano Server LTSC(장기 서비스 채널) 2022를 기본 운영 체제로 사용하여 Windows 베이스를 명시적으로 호출합니다.
참고 항목
Windows 컨테이너인 경우에도 경로에서 여전히 슬래시를 사용해야 합니다. 자세한 내용은 Dockerfile 작성을 참조하세요.
Azure CLI에 로그인합니다.
az login
Azure Container Registry에 로그인합니다.
az acr login -n <your_registry_name>
컨테이너 이미지를 빌드합니다. 이미지 이름을 dotnetcore-docs-hello-world-windows로 지정합니다.
docker build -f Dockerfile.windows -t <your_registry_name>.azurecr.io/dotnetcore-docs-hello-world-windows .
컨테이너 이미지를 Azure Container Registry에 푸시합니다.
docker push <your_registry_name>.azurecr.io/dotnetcore-docs-hello-world-windows:latest
참고 항목
Dockerfile은 내부적으로 포트 번호를 80으로 설정합니다. 컨테이너를 구성하는 방법에 대한 자세한 내용은 사용자 지정 컨테이너 구성을 참조하세요.
3 - Azure에 배포
Azure Portal에 로그인
Azure Portal에 로그인합니다.
Azure 리소스 만들기
검색에 앱 서비스를 입력합니다. 서비스 아래에서 App Services를 선택합니다.
App Services 페이지에서 + 만들기를 선택합니다.
기본 탭의 프로젝트 세부 정보 아래에서 올바른 구독이 선택되어 있는지 확인한 다음, 새 리소스 그룹 만들기를 선택합니다. 이름으로 myResourceGroup을 입력합니다.
인스턴스 세부 정보 아래에서 전역적으로 고유한 웹앱 이름을 입력하고, Docker 컨테이너를 선택합니다. 운영 체제에 대해 Windows를 선택합니다. 앱을 제공하려는 지역을 선택합니다.
App Service 요금제에서 새 App Service 요금제 만들기를 선택합니다. 이름으로 myAppServicePlan을 입력합니다. 무료 계층으로 변경하려면 크기 변경, 개발/테스트 탭, P1v3을 차례로 선택하고, 페이지 아래쪽에서 적용 단추를 선택합니다.
페이지 아래쪽에서 다음: Docker > 단추를 선택합니다.
Docker 탭에서 이미지 원본에 대해 Azure Container Registry를 선택합니다. Azure Container Registry 옵션 아래에서 다음 값을 설정합니다.
- 레지스트리: Azure Container Registry를 선택합니다.
- 이미지: dotnetcore-docs-hello-world-windows를 선택합니다.
- 태그: latest를 선택합니다.
페이지 아래쪽에서 검토 + 만들기 단추를 선택합니다.
유효성 검사를 실행한 후 페이지 아래쪽에서 생성하기 단추를 선택합니다.
배포가 완료되면 리소스로 이동을 선택합니다.
4 - 앱으로 이동
웹 브라우저에서 배포된 애플리케이션(URL: http://<app-name>.azurewebsites.net
)으로 이동합니다.
호스트 운영 체제가 바닥글에 표시되어 Windows 컨테이너에서 실행되고 있음을 확인합니다.
5 - 리소스 정리
이전 단계에서는 리소스 그룹에서 Azure 리소스를 만들었습니다. 나중에 이러한 리소스가 필요하지 않은 경우에 리소스 그룹을 삭제하여 삭제할 수 있습니다.
Azure Portal 메뉴 또는 홈 페이지에서 리소스 그룹을 선택합니다. 그런 다음, 리소스 그룹 페이지에서 myResourceGroup을 선택합니다.
myResourceGroup 페이지에서 나열된 리소스가 삭제하려는 리소스인지 확인합니다.
리소스 그룹 삭제를 선택하고, 텍스트 상자에서 myResourceGroup을 입력하여 확인한 다음, 삭제를 선택합니다.
다음 단계
축하합니다. 이 빠른 시작을 성공적으로 완료하셨습니다.
App Service 앱은 시작할 때마다 컨테이너 레지스트리에서 이미지를 가져옵니다. 이미지를 다시 빌드하는 경우 컨테이너 레지스트리에 푸시하기만 하면 앱이 다시 시작될 때 업데이트된 이미지를 가져옵니다. 업데이트된 이미지를 즉시 가져오도록 앱에 지시하려면 다시 시작합니다.
Azure App Service는 IIS에서 실행하는 ASP.NET 또는 Node.js와 같은 Windows에서 미리 정의된 애플리케이션 스택을 제공합니다. 그러나 미리 구성된 애플리케이션 스택은 운영 체제를 잠그고 낮은 수준의 액세스를 차단합니다. 사용자 지정 Windows 컨테이너에는 이러한 제한이 없으며 개발자가 컨테이너를 완전히 사용자 지정하고 컨테이너화된 애플리케이션에 Windows 기능에 대한 모든 권한을 부여할 수 있습니다.
이 빠른 시작에서는 Microsoft Artifact Registry에서 Azure App Service로 Windows의 ASP.NET 앱을 배포하는 방법을 보여 줍니다.
이 빠른 시작을 완료하려면 다음이 필요합니다.
- 활성 구독이 있는 Azure 계정. 체험 계정을 만듭니다.
- Azure PowerShell.
1 - Azure에 연결
Connect-AzAccount
명령을 사용하고 프롬프트에 따라 Azure 계정에 로그인합니다.
Connect-AzAccount
2 - 리소스 그룹 만들기
New-AzResourceGroup 명령을 사용하여 리소스 그룹을 만듭니다. Azure 리소스 그룹은 Azure 리소스가 배포 및 관리되는 논리적 컨테이너입니다.
다음 예제에서는 eastus 위치에 myResourceGroup이라는 리소스 그룹을 만듭니다. App Service에 지원되는 모든 위치를 확인하려면 Get-AzLocation
명령을 실행합니다.
New-AzResourceGroup -Name myResourceGroup -Location eastus
완료되면 이 명령은 Login Succeeded
를 반환합니다.
3 - App Service 플랜 만들기
New-AzAppServicePlan 명령을 사용하여 새 App Service 계획을 만듭니다.
다음 예제에서는 PremiumV3 가격 책정 계층(-Tier PremiumV3
)에 myAppServicePlan
이라는 App Service 계획을 만듭니다. -HyperV
매개 변수는 Windows 컨테이너를 지정합니다.
New-AzAppServicePlan -Name myAppServicePlan -Location eastus -ResourceGroupName myResourceGroup -Tier PremiumV3 -HyperV
4 - 웹앱 만들기
New-AzWebApp 명령을 사용하여 새 앱을 만듭니다.
New-AzWebApp -Name myWebApp -AppServicePlan myAppServicePlan -Location eastus -ResourceGroupName myResourceGroup -ContainerImageName mcr.microsoft.com/azure-app-service/windows/parkingpage:latest
- Name 매개 변수는 웹앱 이름을 지정합니다.
- AppServicePlan 매개 변수는 App Service 계획 이름을 지정합니다.
- Location 매개 변수는 위치를 지정합니다.
- ResourceGroupName 매개 변수는 리소스 그룹의 이름을 지정합니다.
- ContainerImageName 매개 변수는 컨테이너 이미지 이름과 선택적 태그를 지정합니다.
명령을 완료하는 데 몇 분 정도 걸릴 수 있습니다.
5 - 앱으로 이동
웹 브라우저에서 배포된 애플리케이션(URL: http://<app-name>.azurewebsites.net
)으로 이동합니다.
6 - 리소스 정리
Remove-AzResourceGroup 명령을 사용하여 리소스 그룹을 제거합니다.
Remove-AzResourceGroup myResourceGroup
다음 단계
축하합니다. 이 빠른 시작을 성공적으로 완료하셨습니다.
App Service 앱은 시작할 때마다 컨테이너 레지스트리에서 이미지를 가져옵니다. 이미지를 다시 빌드하는 경우 컨테이너 레지스트리에 푸시하기만 하면 앱이 다시 시작될 때 업데이트된 이미지를 가져옵니다. 업데이트된 이미지를 즉시 가져오도록 앱에 지시하려면 다시 시작합니다.
Azure App Service는 IIS에서 실행하는 ASP.NET 또는 Node.js와 같은 Windows에서 미리 정의된 애플리케이션 스택을 제공합니다. 그러나 미리 구성된 애플리케이션 스택은 운영 체제를 잠그고 낮은 수준의 액세스를 차단합니다. 사용자 지정 Windows 컨테이너에는 이러한 제한이 없으며 개발자가 컨테이너를 완전히 사용자 지정하고 컨테이너화된 애플리케이션에 Windows 기능에 대한 모든 권한을 부여할 수 있습니다.
이 빠른 시작에서는 Microsoft Artifact Registry에서 Azure App Service로 Windows의 ASP.NET 앱을 배포하는 방법을 보여 줍니다.
이 빠른 시작을 완료하려면 다음이 필요합니다.
- 활성 구독이 있는 Azure 계정. 체험 계정을 만듭니다.
- Azure CLI
1 - Azure에 연결
az login
명령을 사용하고 프롬프트에 따라 Azure 계정에 로그인합니다.
az login
2 - 리소스 그룹 만들기
az group create
명령을 사용하여 리소스 그룹을 만듭니다. Azure 리소스 그룹은 Azure 리소스가 배포 및 관리되는 논리적 컨테이너입니다.
다음 예제에서는 eastus 위치에 myResourceGroup이라는 리소스 그룹을 만듭니다. App Service에 지원되는 모든 위치를 확인하려면 az appservice list-locations
명령을 실행합니다.
az group create --name myResourceGroup --location eastus
3 - App Service 플랜 만들기
az appservice plan create
명령을 사용하여 리소스 그룹에 App Service 계획을 만듭니다.
다음 예제에서는 P1V3 가격 책정 계층(--sku P1V3
)에서 myAppServicePlan
이라는 App Service 요금제를 만듭니다.
az appservice plan create --resource-group myResourceGroup --location eastus --name myAppServicePlan --hyper-v --sku p1v3
참고 항목
"이 명령의 동작이 다음 확장인 appservice-kube에 의해 변경되었습니다."라는 오류가 발생하면 appservice-kube
확장을 제거합니다.
4 - 웹앱 만들기
az webapp create 명령을 사용하여 myAppServicePlan
App Service 계획에서 사용자 지정 컨테이너 웹앱을 만듭니다. myContainerApp을 고유한 앱 이름으로 바꿔야 합니다(유효한 문자는 a-z
, 0-9
및 -
임).
az webapp create --name myContainerApp --plan myAppServicePlan --location eastus --resource-group myResourceGroup --deployment-container-image-name mcr.microsoft.com/azure-app-service/windows/parkingpage:latest
- Name 매개 변수는 웹앱 이름을 지정합니다.
- AppServicePlan 매개 변수는 App Service 계획 이름을 지정합니다.
- Location 매개 변수는 위치를 지정합니다.
- ResourceGroupName 매개 변수는 리소스 그룹의 이름을 지정합니다.
- deployment-container-image-name 매개 변수는 컨테이너 이미지 이름과 선택적 태그를 지정합니다.
5 - 앱으로 이동
웹 브라우저에서 배포된 애플리케이션(URL: http://<app-name>.azurewebsites.net
)으로 이동합니다.
6 - 리소스 정리
az group delete 명령을 사용하여 리소스 그룹을 제거합니다.
az group delete --no-wait --name <resource_group>
다음 단계
축하합니다. 이 빠른 시작을 성공적으로 완료하셨습니다.
App Service 앱은 시작할 때마다 컨테이너 레지스트리에서 이미지를 가져옵니다. 이미지를 다시 빌드하는 경우 컨테이너 레지스트리에 푸시하기만 하면 앱이 다시 시작될 때 업데이트된 이미지를 가져옵니다. 업데이트된 이미지를 즉시 가져오도록 앱에 지시하려면 다시 시작합니다.