다음을 통해 공유


자습서: App Services 웹앱을 사용하여 가상 네트워크에 Azure Database for PostgreSQL - 유연한 서버 인스턴스 만들기

적용 대상: Azure Database for PostgreSQL - 유연한 서버

이 자습서에서는 Azure Database for PostgreSQL 유연한 서버를 사용하여 가상 네트워크 내에 Azure App Service 웹앱을 만드는 방법을 보여 줍니다.

이 자습서에서는 다음 방법에 대해 알아봅니다.

  • 가상 네트워크에서 Azure Database for PostgreSQL 유연한 서버 인스턴스 만들기
  • 웹앱 만들기
  • 가상 네트워크에 웹앱 추가
  • 웹앱에서 Azure Database for PostgreSQL 유연한 서버에 연결

필수 조건

  • Azure 구독이 없는 경우 시작하기 전에 체험 계정을 만듭니다.

  • 로컬에 Azure CLI 버전 2.0 이상을 설치합니다(또는 CLI가 사전 설치된 Azure Cloud Shell 사용). 설치된 버전을 확인하려면 az --version 명령을 실행합니다.

  • az login 명령을 사용하여 계정에 로그인합니다. 해당 구독 이름에 대한 명령 출력에서 id 속성을 참고합니다.

    az login
    
  • 구독이 여러 개인 경우 리소스가 과금되어야 할 적절한 구독을 선택합니다. az account set 명령을 사용하여 계정에 속한 특정 구독 ID를 선택합니다.

    az account set --subscription <subscription ID>
    

새 가상 네트워크에서 Azure Database for PostgreSQL 유연한 서버 인스턴스 만들기

다음 명령을 사용하여 VNET(가상 네트워크) 내에 프라이빗 Azure Database for PostgreSQL 유연한 서버 인스턴스를 만듭니다.

az postgres flexible-server create --resource-group demoresourcegroup --name demoserverpostgres --vnet demoappvnet --location westus2

이 명령은 다음 작업을 수행하며 몇 분 정도 걸릴 수 있습니다.

  • 리소스 그룹이 없는 경우 생성합니다.
  • 서버 이름을 입력하지 않은 경우 서버 이름을 생성합니다.
  • Azure Database for PostgreSQL 유연한 서버 인스턴스에 대한 가상 네트워크 및 서브넷을 만듭니다.
  • 제공되지 않은 경우 서버에 대한 관리 사용자 이름과 암호를 만듭니다.
  • postgres라는 빈 데이터베이스를 만듭니다.

샘플 출력은 다음과 같습니다.

Creating Resource Group 'demoresourcegroup'...
Creating new Vnet "demoappvnet" in resource group "demoresourcegroup"
Creating new Subnet "Subnetdemoserverpostgres" in resource group "demoresourcegroup"
Creating a private dns zone demoserverpostgres.private.postgres.database.azure.com in resource group "demoresourcegroup"
Creating PostgreSQL Server 'demoserverpostgres' in group 'demoresourcegroup'...
Your server 'demoserverpostgres' is using sku 'Standard_D2s_v3' (Paid Tier). Please refer to https://aka.ms/postgres-pricing for pricing details
Creating PostgreSQL database 'flexibleserverdb'...
Make a note of your password. If you forget, you would have to reset your password with "az postgres flexible-server update -n demoserverpostgres -g demoresourcegroup -p <new-password>".
Try using 'az postgres flexible-server connect' command to test out connection.
{
  "connectionString": "postgresql://generated-username:generated-password@demoserverpostgres.postgres.database.azure.com/postgres?sslmode=require",
  "host": "demoserverpostgres.postgres.database.azure.com",
  "id": "/subscriptions/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx/resourceGroups/demoresourcegroup/providers/Microsoft.DBforPostgreSQL/flexibleServers/demoserverpostgres",
  "location": "East US",
  "password": "generated-password",
  "resourceGroup": "demoresourcegroup",
  "skuname": "Standard_D2s_v3",
  "subnetId": "/subscriptions/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx/resourceGroups/demoresourcegroup/providers/Microsoft.Network/virtualNetworks/demoappvnet/subnets/Subnetdemoserverpostgres",
  "username": "generated-username",
  "version": "12"
}

웹앱 만들기

이 섹션에서는 App Service 앱에서 앱 호스트를 만들고, 이 앱을 Azure Database for PostgreSQL 유연한 서버 데이터베이스에 연결한 다음, 해당 호스트에 코드를 배포합니다. 터미널에서 애플리케이션 코드의 리포지토리 루트에 있는지 확인합니다. 참고 기본 계획은 VNet 통합을 지원하지 않습니다. 표준 또는 프리미엄을 사용합니다.

az webapp up 명령을 사용하여 App Service 앱(호스트 프로세스)을 만듭니다.

az webapp up --resource-group demoresourcegroup --location westus2 --plan testappserviceplan --sku P2V2 --name mywebapp

참고 항목

  • --location 인수의 경우 이전 섹션의 데이터베이스에 사용한 것과 동일한 위치를 사용합니다.
  • <app-name>을 모든 Azure에서 고유한 이름으로 바꿉니다. <app-name>에 허용되는 문자는 A-Z, 0-9 및 -입니다. 회사 이름과 앱 식별자를 조합하여 사용하는 것이 좋습니다.

이 명령은 다음 작업을 수행하며 몇 분 정도 걸릴 수 있습니다.

  • 아직 없는 경우 리소스 그룹을 만듭니다. (이 명령에서는 이전에 데이터베이스를 만든 것과 동일한 리소스 그룹을 사용합니다.)
  • 없는 경우 App Service 앱을 만듭니다.
  • 아직 사용하도록 설정되지 않은 경우 기본 로깅을 앱에 사용하도록 설정합니다.
  • 빌드 자동화를 사용하도록 설정된 ZIP 배포를 사용하여 리포지토리를 업로드합니다.

웹앱을 위한 서브넷 만들기

VNET 통합을 사용하도록 설정하려면 App Service 웹앱에 위임된 서브넷이 있어야 합니다. 서브넷을 만들기 전에 데이터베이스 서브넷 주소를 확인하여 웹앱 서브넷에 동일한 주소 접두사가 사용되지 않도록 합니다.

az network vnet show --resource-group demoresourcegroup -n demoappvnet

다음 명령을 실행하여 Azure Database for PostgreSQL 유연한 서버가 생성된 가상 네트워크와 동일한 가상 네트워크에 새 서브넷을 만듭니다. Azure Database for PostgreSQL 유연한 서버 서브넷과의 충돌을 방지하기 위해 주소 접두사를 업데이트합니다.

az network vnet subnet create --resource-group demoresourcegroup --vnet-name demoappvnet --name webappsubnet  --address-prefixes 10.0.1.0/24  --delegations Microsoft.Web/serverFarms

가상 네트워크에 웹앱 추가

az webapp vnet-integration 명령을 사용하여 지역 가상 네트워크 통합을 웹앱에 추가합니다.

az webapp vnet-integration add --resource-group demoresourcegroup -n  mywebapp --vnet demoappvnet --subnet webappsubnet

데이터베이스를 연결하도록 환경 변수 구성

이제 코드가 App Service에 배포되었습니다. 다음 단계는 Azure에서 앱을 Azure Database for PostgreSQL 유연한 서버 인스턴스에 연결하는 것입니다. 앱 코드는 다양한 환경 변수에서 데이터베이스 정보를 찾을 것으로 예상합니다. App Service에서 환경 변수를 설정하려면 az webapp config appsettings set 명령을 사용합니다.

  
az webapp config appsettings set  --name mywebapp --settings DBHOST="<postgres-server-name>.postgres.database.azure.com" DBNAME="postgres" DBUSER="<username>" DBPASS="<password>" 
  • 새로 생성된 Azure Database for PostgreSQL 유연한 서버 인스턴스 명령에 대해 postgres-server-name, username, password를 바꿉니다.
  • <username><password>를 명령에서 자동으로 생성한 자격 증명으로 바꿉니다.
  • 리소스 그룹 및 앱 이름은 .azure/config 파일의 캐시된 값에서 가져옵니다.
  • 명령은 DBHOST, DBNAME, DBUSER*, DBPASS라는 설정을 만듭니다. 애플리케이션 코드에서 데이터베이스 정보에 다른 이름을 사용하는 경우 코드에 설명된 대로 해당 이름을 앱 설정에 사용하세요.

가상 네트워크 내에서의 모든 아웃바운드 연결을 허용하도록 웹앱을 구성합니다.

az webapp config set --name mywebapp --resource-group demoresourcegroup --generic-configurations '{"vnetRouteAllEnabled": true}'

리소스 정리

다음 명령을 사용하여 자습서에서 만든 모든 리소스를 정리합니다. 이 명령은 리소스 그룹에 있는 모든 리소스를 삭제합니다.

az group delete -n demoresourcegroup