연습 - 환경 설정

완료됨

이 섹션에서는 Azure DevOps 조직이 이 모듈의 나머지 부분을 완료하도록 설정합니다. 또한 배포 대상인 Azure App Service 환경을 만듭니다.

목표를 달성하기 위해 다음을 수행합니다.

  • Azure DevOps에서 Azure 구독에 연결할 수 있는지 확인하기 위해 사용자를 추가합니다.
  • 이 모듈의 Azure DevOps 프로젝트를 설정합니다.
  • Azure Boards에서 이 모듈의 작업 항목을 실행 중 열로 이동합니다.
  • 파이프라인에 변경 내용을 푸시할 수 있도록 프로젝트가 로컬로 설정되어 있는지 확인합니다.
  • Azure Cloud Shell에서 Azure CLI를 사용하여 Azure App Service 환경을 만듭니다.
  • App Service 환경의 이름을 정의하는 파이프라인 변수를 만듭니다.
  • Azure Pipelines가 Azure 구독에 안전하게 액세스할 수 있게 지원하는 서비스 연결을 만듭니다.
  • 초기 배포를 수행합니다.

Azure DevOps에 사용자 추가

이 모듈을 완료하려면 자체 Azure 구독이 필요합니다. Azure 평가판을 시작할 수 있습니다.

Azure DevOps를 사용하는 데 Azure 구독이 필요하지는 않지만, 여기서는 Azure DevOps를 사용하여 Azure 구독에 있는 리소스에 배포합니다. 프로세스를 간소화하려면 동일한 Microsoft 계정을 사용하여 Azure 구독과 Azure DevOps 조직에 모두 로그인합니다.

서로 다른 Microsoft 계정을 사용하여 Azure 및 Azure DevOps에 로그인할 경우 Azure에 로그인하는 데 사용하는 Microsoft 계정의 DevOps 조직에 사용자를 추가합니다. 자세한 내용은 조직 또는 프로젝트에 사용자 추가를 참조하세요. 사용자를 추가하는 경우 기본 액세스 수준을 선택합니다.

그런 다음 Azure DevOps에서 로그아웃하고 Azure 구독에 로그인하는 데 사용하는 Microsoft 계정으로 다시 로그인합니다.

Azure DevOps 프로젝트 가져오기

여기서는 Azure DevOps 조직이 이 모듈의 나머지 부분을 완료하도록 설정합니다. Azure DevOps에서 프로젝트를 만드는 템플릿을 실행하면 됩니다.

이 학습 경로의 모듈은 진행 과정을 구성합니다. Tailspin 웹 팀이 DevOps를 경험하는 과정을 따라갑니다. 학습 목적을 위해 각 모듈에는 연결된 Azure DevOps 프로젝트가 있습니다.

템플릿 실행

Azure DevOps 조직을 설정하는 템플릿을 실행합니다.

Azure DevOps Demo Generator 사이트에서 다음 단계를 수행하여 템플릿을 실행합니다.

  1. 로그인을 선택하고 사용 약관에 동의합니다.

  2. 새 프로젝트 만들기 페이지에서 Azure DevOps 조직을 선택합니다. 그런 다음 Space Game - web - Deployment patterns 등의 프로젝트 이름을 입력합니다.

    Screenshot that shows how to create a project through the Azure DevOps Demo Generator.

  3. 예, 이 리포지토리를 포크하겠습니다를 선택합니다. 그런 다음 권한 부여를 선택합니다.

  4. Create Project를 선택합니다.

    템플릿을 실행하는 데 몇 분 정도 걸립니다.

  5. Navigate to project를 선택하여 Azure DevOps의 해당 프로젝트로 이동합니다.

중요

이 모듈의 Azure DevOps 환경 정리 페이지에는 중요한 정리 단계가 포함되어 있습니다. 환경을 정리하면 사용 가능한 빌드 시간을 늘릴 수 있습니다. 이 모듈을 완료하지 않더라도 정리 단계를 수행해야 합니다.

프로젝트의 표시 유형 설정

처음에는 GitHub의 Space Game 리포지토리 포크가 퍼블릭으로 설정되고 Azure DevOps 템플릿에서 만든 프로젝트는 프라이빗으로 설정됩니다. GitHub의 퍼블릭 리포지토리에는 누구나 액세스할 수 있으며, 프라이빗 리포지토리는 사용자와 공유하도록 선택한 사용자만 액세스할 수 있습니다. 마찬가지로 Azure DevOps에서 퍼블릭 프로젝트는 인증되지 않은 사용자에게 읽기 전용 액세스를 제공하는 반면, 프라이빗 프로젝트는 사용자에게 액세스 권한을 부여하고 서비스에 액세스하기 위해 인증을 받아야 합니다.

현재로서는 이 모듈의 목적을 위해 이러한 설정을 수정할 필요가 없습니다. 그러나 개인 프로젝트의 경우 다른 사용자에게 부여하려는 표시 유형 및 액세스를 결정해야 합니다. 예를 들어 프로젝트가 오픈 소스인 경우 GitHub 리포지토리와 Azure DevOps 프로젝트를 모두 퍼블릭 상태로 만들지 선택할 수 있습니다. 프로젝트가 재산적 가치를 가지는 경우 일반적으로 GitHub 리포지토리와 Azure DevOps 프로젝트를 모두 프라이빗 상태로 설정할 수 있습니다.

나중에 프로젝트에 가장 적합한 옵션을 결정하는 데 도움이 되는 다음과 같은 리소스를 찾을 수 있습니다.

작업 항목을 실행 중으로 이동

Azure Boards에서 이 모듈과 관련된 작업 항목을 자신에게 할당합니다. 또한 작업 항목을 실행 중 상태로 이동합니다. 실제로 팀에서는 각 ‘스프린트’를 시작하거나 반복 작업을 수행할 때 작업 항목을 만듭니다.

작업을 이 방법으로 할당하면 작업 검사 목록이 제공됩니다. 이 목록은 팀에게 현재 수행 중인 작업과 남아 있는 작업량을 보여 줍니다. 또한 WIP(진행 중인 작업)에 제한을 적용하여 팀이 한 번에 너무 많은 작업을 수행하지 않도록 하는 데 도움이 됩니다.

팀은 현재 스프린트의 주요 문제에 관해 다음과 같이 합의했습니다.

Screenshot of Azure Boards that shows the tasks for this sprint.

참고 항목

Azure DevOps 조직 내에서 작업 항목은 순차적으로 번호가 지정됩니다. 프로젝트에서 각 작업 항목의 번호가 여기에 표시된 것과 일치하지 않을 수 있습니다.

여기서 다섯 번째 항목인 릴리스 주기 개선실행 중 열로 이동합니다. 그런 다음 자신을 작업 항목에 할당합니다. 릴리스 주기 개선은 사용자에게 변경 내용을 신속하게 릴리스할 수 있는 배포 패턴을 선택하는 것과 관련이 있습니다.

작업 항목을 설정하려면 다음을 수행합니다.

  1. Azure DevOps에서 Boards로 이동한 다음, 메뉴에서 보드를 선택합니다.

    Screenshot of Azure DevOps that shows the location of the Boards menu.

  2. 릴리스 주기 개선 작업 항목 하단에 아래쪽 화살표를 선택합니다. 그런 다음 작업 항목을 자신에게 할당합니다.

    Screenshot of Azure Boards that shows the location of the down arrow.

  3. 작업 항목을 To Do 열에서 Doing 열로 이동합니다.

    Screenshot of Azure Boards that shows the card in the Doing column.

이 모듈의 마지막에 작업을 완료한 후 카드를 완료 열로 옮깁니다.

로컬로 프로젝트 설정

여기서는 Visual Studio Code에서 Space Game 프로젝트를 로드하고, Git을 구성하며 리포지토리를 로컬로 복제하고 시작 코드를 다운로드할 수 있도록 업스트림 원격을 설정합니다.

참고

이미 mslearn-tailspin-spacegame-web-deploy 프로젝트를 로컬에 설정한 경우 다음 섹션으로 이동할 수 있습니다.

통합 터미널 열기

Visual Studio Code는 통합 터미널과 함께 제공됩니다. 여기서는 파일을 편집하고 명령줄에서 작업을 수행합니다.

  1. Visual Studio Code를 시작합니다.

  2. 보기 메뉴에서 터미널을 선택합니다.

  3. 드롭다운 목록에서 Git Bash를 선택합니다. 다른 Unix 셸 사용에 익숙하다면 대신 해당 셸을 선택합니다.

    A screenshot of Visual Studio Code showing the location of the Git Bash shell.

    터미널 창에서 시스템에 설치된 모든 셸을 선택할 수 있습니다. 예를 들어 Git Bash나 PowerShell이나 다른 셸을 선택할 수 있습니다.

    여기서는 Git 명령을 쉽게 실행할 수 있도록 하는 Windows용 Git의 일부인 Git Bash를 사용합니다.

    참고 항목

    Windows에서 Git Bash가 옵션으로 표시되지 않으면 Git을 설치했는지 확인한 다음, Visual Studio Code를 다시 시작합니다.

  4. cd 명령을 실행하여 작업할 디렉터리로 이동합니다. 원하는 경우 홈 디렉터리(~) 또는 다른 디렉터리를 선택합니다.

    cd ~
    

Git 구성

Git 및 GitHub를 처음 사용하는 경우, 먼저 몇 가지 명령을 실행하여 ID를 Git에 연결하고 GitHub에 인증합니다. 자세한 내용은 Set up Git(Git 설정)을 참조하세요.

최소한 다음 단계를 완료해야 합니다. 통합 터미널에서 다음 명령을 실행합니다.

  1. 사용자 이름을 설정합니다.
  2. 커밋 메일 주소를 설정합니다.
  3. GitHub 암호를 캐시합니다.

참고

이미 GitHub에서 2단계 인증을 사용하고 있는 경우 개인용 액세스 토큰을 만듭니다. 프롬프트가 표시되면 암호 대신 토큰을 사용합니다.

액세스 토큰을 암호와 같이 취급하고 안전하게 보관하세요.

Visual Studio Code에서 프로젝트 설정

Azure DevOps로 애플리케이션 빌드 학습 경로에서는 Git 리포지토리를 포크한 다음 복제했습니다. 리포지토리에는 Space Game 웹 사이트의 소스 코드가 포함되어 있습니다. 포크는 GitHub에 변경 내용을 푸시할 때 빌드가 실행되도록 Azure DevOps의 프로젝트에 연결되었습니다.

중요

이 학습 경로에서 다른 Git 리포지토리인 mslearn-tailspin-spacegame-web-deploy로 전환합니다. 템플릿을 실행하여 Azure DevOps 프로젝트를 설정했을 때 프로세스에서 자동으로 리포지토리를 포크했습니다.

이 파트에서는 파이프라인 구성을 변경하고 빌드할 수 있도록 포크를 로컬로 복제합니다.

로컬로 포크 복제

GitHub 계정에 Space Game 웹 프로젝트의 복사본이 있습니다. 이제 복사본으로 작업할 수 있도록 컴퓨터에 해당 복사본을 다운로드하거나 ‘복제’합니다.

포크와 마찬가지로 복제본은 리포지토리의 복사본입니다. 리포지토리를 복제할 때 변경을 수행하고 예상대로 작동하는지 확인한 다음, 해당 변경 내용을 GitHub에 업로드할 수 있습니다. 또한 인증된 다른 사용자가 리포지토리의 GitHub 복사본에 변경한 내용과 로컬 복사본을 동기화할 수 있습니다.

Space Game 웹 프로젝트를 컴퓨터에 복제하려면 다음을 수행합니다.

  1. GitHub에서 Space Game 웹 프로젝트의 포크(mslearn-tailspin-spacegame-web-deploy)로 이동합니다.

  2. 코드를 선택합니다. 그런 다음, HTTPS 탭에서 표시된 URL 옆에 있는 단추를 선택하여 URL을 클립보드에 복사합니다.

    Screenshot that shows how to locate the URL and copy button from the GitHub repository.

  3. Visual Studio Code에서 터미널 창으로 이동합니다.

  4. 터미널에서 작업하려는 디렉터리로 이동합니다. 원하는 경우 홈 디렉터리(~) 또는 다른 디렉터리를 선택합니다.

    cd ~
    
  5. git clone 명령을 실행합니다. 여기에 표시된 URL을 클립보드의 내용으로 바꿉니다.

    git clone https://github.com/your-name/mslearn-tailspin-spacegame-web-deploy.git
    
  6. mslearn-tailspin-spacegame-web-deploy 디렉터리로 이동합니다. 이 디렉터리는 리포지토리의 루트 디렉터리입니다.

    cd mslearn-tailspin-spacegame-web-deploy
    

업스트림 원격 설정

‘원격’은 GitHub의 리포지토리처럼 팀 구성원이 협업하는 Git 리포지토리입니다. 여기에서 원격을 나열하고 Microsoft의 리포지토리 복사본을 가리키는 원격을 추가하여 최신 샘플 코드를 얻을 수 있습니다.

  1. 원격을 나열하려면 다음과 같이 git remote 명령을 실행합니다.

    git remote -v
    

    다음과 같이 리포지토리에 대한 페치(다운로드) 및 푸시(업로드) 액세스 권한이 모두 있는 것을 확인할 수 있습니다.

    origin  https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (fetch)
    origin  https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (push)
    

    Origin은 GitHub의 리포지토리를 지정합니다. 다른 리포지토리의 코드를 포크할 때 원본 원격(포크한 원격)을 보통 ‘업스트림’이라고 합니다.

  2. 다음과 같이 git remote add 명령을 실행하여 Microsoft 리포지토리를 가리키는 upstream이라는 원격을 만듭니다.

    git remote add upstream https://github.com/MicrosoftDocs/mslearn-tailspin-spacegame-web-deploy.git
    
  3. git remote를 다시 실행하여 변경 내용을 확인합니다.

    git remote -v
    

    여전히 리포지토리에 대한 페치(다운로드) 및 푸시(업로드) 액세스 권한이 모두 있음을 확인할 수 있습니다. 그리고 이제 Microsoft 리포지토리에 대한 페치 액세스 권한도 있습니다.

    origin  https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (fetch)
    origin  https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (push)
    upstream        https://github.com/MicrosoftDocs/mslearn-tailspin-spacegame-web-deploy.git (fetch)
    

파일 탐색기에서 프로젝트 열기

Visual Studio Code에서 터미널 창은 Space Game 웹 프로젝트의 루트 디렉터리를 가리킵니다. 파일 구조를 보고 파일을 사용하려면 파일 탐색기에서 이제 프로젝트를 엽니다.

  1. 프로젝트를 여는 가장 쉬운 방법은 현재 디렉터리에서 Visual Studio Code를 다시 여는 것입니다. 이렇게 하려면 통합 터미널에서 다음 명령을 실행합니다.

    code -r .
    

    파일 탐색기에 디렉터리 및 파일 트리가 표시됩니다.

  2. 통합 터미널을 다시 엽니다. 터미널을 실행하면 웹 프로젝트의 루트에서 시작됩니다.

code 명령이 실패하면 시스템 PATH에 Visual Studio Code를 추가해야 합니다. 이를 수행하려면:

  1. Visual Studio Code에서 F1을 선택하거나 보기>명령 팔레트를 선택하여 명령 팔레트에 액세스합니다.
  2. 명령 팔레트에서 ‘셸 명령: PATH에 ‘code’ 명령 설치’.
  3. 이전 절차를 반복하여 파일 탐색기에서 프로젝트를 엽니다.

이제 로컬 개발 환경에서 Space Game 소스 코드 및 Azure Pipelines 구성을 사용하여 작업하도록 설정되었습니다.

Azure App Service 환경 만들기

여기서는 파이프라인 단계를 정의하는 환경을 만듭니다. 각 단계(‘개발’, ‘테스트’, ‘스테이징’)에 해당하는 App Service 인스턴스 하나를 만듭니다.

이전 모듈에서는 Azure CLI를 사용하여 App Service 인스턴스를 만들었습니다. 여기서도 똑같이 만듭니다.

중요

이 모듈의 연습을 완료하려면 자체 Azure 구독이 필요합니다.

Azure Portal을 통해 Cloud Shell 가져오기

  1. Azure Portal로 이동하고 로그인합니다.
  2. 메뉴에서 Cloud Shell을 선택합니다. 프롬프트가 표시되면 Bash 환경을 선택합니다.

Azure 지역 선택

여기서는 Azure 리소스가 생성될 기본 ‘지역’ 또는 지리적 위치를 지정합니다.

  1. Cloud Shell에서 다음 az account list-locations 명령을 실행하여 Azure 구독에서 사용할 수 있는 지역을 나열합니다.

    az account list-locations \
      --query "[].{Name: name, DisplayName: displayName}" \
      --output table
    
  2. 출력의 이름 열에서, 가까운 지역을 선택합니다. 예를 들어 eastasia 또는 westus2를 선택합니다.

  3. az configure를 실행하여 기본 지역을 설정합니다. <REGION>을 선택한 영역의 이름으로 바꿉니다.

    az configure --defaults location=<REGION>
    

    이 예에서는 westus2를 기본 지역으로 설정합니다.

    az configure --defaults location=westus2
    

App Service 인스턴스 만들기

여기서는 배포할 세 단계인 ‘개발’, ‘테스트’, ‘스테이징’ 단계에 대한 App Service 인스턴스를 만듭니다. 이 모듈의 뒷부분에서 ‘스테이징’에 배포 슬롯을 추가합니다.

참고

학습 목적을 위해 여기서는 기본 네트워크 설정을 사용합니다. 기본 설정을 통해 인터넷에서 사이트에 액세스할 수 있습니다. 실제로는 인터넷에서 라우팅할 수 없지만, 팀만 액세스할 수 있는 네트워크에 웹 사이트를 배치하는 Azure 가상 네트워크를 구성할 수 있습니다. 나중에 준비를 마치면 사용자가 웹 사이트를 사용할 수 있도록 네트워크를 다시 구성할 수 있습니다.

  1. Cloud Shell에서 웹앱의 도메인 이름을 고유하게 만드는 난수를 생성합니다.

    webappsuffix=$RANDOM
    
  2. 다음 az group create 명령을 실행하여 tailspin-space-game-rg라는 이름의 리소스 그룹을 만듭니다.

    az group create --name tailspin-space-game-rg
    
  3. 다음 명령을 실행하여 두 개의 App Service 요금제를 만듭니다.

    az appservice plan create \
      --name tailspin-space-game-test-asp \
      --resource-group tailspin-space-game-rg \
      --sku B1 \
      --is-linux
    
    az appservice plan create \
      --name tailspin-space-game-prod-asp \
      --resource-group tailspin-space-game-rg \
      --sku P1V2 \
      --is-linux
    

    중요

    Azure 구독에서 B1 SKU를 사용할 수 없는 경우 S1(표준)과 같은 다른 요금제를 선택합니다.

    App Service 요금제는 웹앱을 실행하기 위해 제공되는 CPU, 메모리, 스토리지 리소스를 정의합니다.

    첫 번째 명령은 B1 요금제를 지정합니다. 이 요금제는 기본 계층에서 실행됩니다. App Service 환경은 ‘개발’, ‘테스트’ 단계에 해당 요금제를 사용합니다. B1 기본 요금제는 개발 또는 테스트 환경과 같이 트래픽 요구 사항이 낮은 앱을 위한 요금제입니다.

    두 번째 명령은 P1V2 요금제를 지정하며, 프리미엄 계층에서 실행됩니다. 이 요금제는 ‘스테이징’에 사용됩니다. 프리미엄 P1V2 요금제는 프로덕션 워크로드를 위한 요금제입니다. 전용 가상 머신 인스턴스에서 실행됩니다.

    기본 요금제 계층은 추가 배포 슬롯을 제공하지 않습니다. 그러나 프리미엄 요금제는 추가 배포 슬롯을 제공합니다. 따라서 ‘스테이징’ 환경에는 ‘프리미엄’ 요금제가 필요합니다.

  4. 다음 az webapp create 명령을 실행하여 개발, 테스트, 스테이징 환경에 하나씩 총 3개의 App Service 인스턴스를 만듭니다.

    az webapp create \
      --name tailspin-space-game-web-dev-$webappsuffix \
      --resource-group tailspin-space-game-rg \
      --plan tailspin-space-game-test-asp \
      --runtime "DOTNET|6.0"
    
    az webapp create \
      --name tailspin-space-game-web-test-$webappsuffix \
      --resource-group tailspin-space-game-rg \
      --plan tailspin-space-game-test-asp \
      --runtime "DOTNET|6.0"
    
    az webapp create \
      --name tailspin-space-game-web-staging-$webappsuffix \
      --resource-group tailspin-space-game-rg \
      --plan tailspin-space-game-prod-asp \
      --runtime "DOTNET|6.0"
    

    여기서는 ‘개발’ 및 ‘테스트’용 App Service 인스턴스에 동일한 App Service 요금제인 B1 기본을 적용합니다. ‘스테이징’용 App Service 인스턴스에는 프리미엄 P1V2 App Service 요금제를 적용합니다.

  5. 다음 az webapp list 명령을 실행하여 각 App Service 인스턴스의 호스트 이름과 상태를 나열합니다.

    az webapp list \
      --resource-group tailspin-space-game-rg \
      --query "[].{hostName: defaultHostName, state: state}" \
      --output table
    

    실행 중인 각 서비스의 호스트 이름을 기록해 둡니다. 호스트 이름은 나중에 작업을 확인할 때 필요합니다. 호스트 이름 예는 다음과 같습니다.

    HostName                                                 State
    -------------------------------------------------------  -------
    tailspin-space-game-web-dev-21017.azurewebsites.net      Running
    tailspin-space-game-web-test-21017.azurewebsites.net     Running
    tailspin-space-game-web-staging-21017.azurewebsites.net  Running
    
  6. 선택적 단계로 하나 이상의 이름으로 이동합니다. 호스트 이름이 실행되고 있고 기본 홈페이지가 표시되는지 확인합니다.

    각 환경에 다음 페이지가 표시됩니다.

    Screenshot of the default home page in Azure App Service.

Important

이 모듈의 Azure DevOps 환경 정리 페이지에는 중요한 정리 단계가 포함되어 있습니다. 또한 정리를 통해 이 모듈을 완료한 후 Azure 리소스에 대한 요금이 청구되지 않도록 할 수 있습니다. 정리 단계는 이 모듈을 완료하지 않은 경우에도 수행해야 합니다.

Azure Pipelines에서 파이프라인 변수 만들기

Azure Pipelines를 사용하여 다단계 파이프라인 만들기에서 파이프라인의 ‘개발’, ‘테스트’, ‘스테이징’ 단계에 해당하는 각 App Service 인스턴스에 대해 하나의 변수를 추가했습니다. 여기서도 똑같이 추가합니다.

파이프라인 구성의 각 단계는 해당 변수를 사용하여 배포할 App Service 인스턴스를 식별합니다.

변수를 추가하려면 다음을 수행합니다.

  1. Azure DevOps에서 Space Game - web - Deployment patterns 프로젝트로 이동합니다.

  2. Pipelines에서 라이브러리를 선택합니다.

    Screenshot of Azure Pipelines that shows the Library menu option.

  3. + 변수 그룹을 선택합니다.

  4. 속성에서 변수 그룹 이름에 ‘릴리스’를 입력합니다.

  5. Variables에서 + Add를 선택합니다.

  6. 변수 이름에 WebAppNameDev를 입력합니다. 변수 값으로 tailspin-space-game-web-dev-1234와 같은 ‘개발’ 환경에 해당하는 App Service 인스턴스의 이름을 입력합니다.

  7. 5단계와 6단계를 두 번 더 반복하여 다음 표와 같이 ‘테스트’ 및 ‘스테이징’ 환경에 대한 변수를 만듭니다.

    변수 이름 예제 값
    WebAppNameTest tailspin-space-game-web-test-1234
    WebAppNameStaging tailspin-space-game-web-staging-1234

    각 예제 값을 사용자 환경에 해당하는 App Service 인스턴스로 바꿔야 합니다.

    중요

    호스트 이름이 아닌 App Service 인스턴스 이름을 설정합니다. 이 예제에서는 tailspin-space-game-web-dev-1234.azurewebsites.net이 아닌 tailspin-space-game-web-dev-1234를 입력합니다.

  8. 페이지 상단에서 저장을 선택하여 변수를 파이프라인에 저장합니다.

    변수 그룹은 다음과 비슷합니다.

    Screenshot of Azure Pipelines that shows the variable group. The group contains three variables.

개발,테스트 및 스테이징 환경을 만듭니다.

이전 모듈에서는 개발, 테스트스테이징 환경을 위한 환경을 만들었습니다. 여기에서 해당 프로세스를 반복합니다.

개발, 테스트스테이징 환경을 만들려면 다음을 수행합니다.

  1. Azure Pipelines에서 환경을 선택합니다.

    Screenshot of Azure Pipelines that shows the location of the Environments menu option.

  2. 개발 환경을 만들려면 다음을 수행합니다.

    1. 환경 만들기를 선택합니다.
    2. 이름에서 dev를 입력합니다.
    3. 나머지 필드는 기본값으로 둡니다.
    4. 만들기를 선택합니다.
  3. 테스트 환경을 만들려면 다음을 수행합니다.

    1. 환경 페이지로 돌아갑니다.
    2. 새 환경을 선택합니다.
    3. 이름에서 test를 입력합니다.
    4. 만들기를 선택합니다.
  4. 스테이징 환경을 만들려면 다음을 수행합니다.

    1. 환경 페이지로 돌아갑니다.
    2. 새 환경을 선택합니다.
    3. 이름staging을 입력합니다.
    4. 만들기를 선택합니다.

서비스 연결 만들기

여기서는 Azure Pipelines가 Azure 구독에 액세스할 수 있도록 지원하는 서비스 연결을 만듭니다. Azure Pipelines는 해당 서비스 연결을 사용하여 웹 사이트를 App Service에 배포합니다. 이전 모듈에서 유사한 서비스 연결을 만들었습니다.

중요

동일한 Microsoft 계정으로 Azure Portal과 Azure DevOps 모두에 로그인했는지 확인합니다.

  1. Azure DevOps에서 Space Game - web - Deployment patterns 프로젝트로 이동합니다.

  2. 페이지 하단 모서리에서 프로젝트 설정을 선택합니다.

  3. Pipelines 아래에서 서비스 연결을 선택합니다.

  4. New service connection, Azure Resource Manager, Next를 차례로 선택합니다.

  5. 페이지 상단에서 Service principal (automatic)을 선택합니다. 그런 후 다음을 선택합니다.

  6. 다음 필드를 입력합니다.

    필드
    범위 수준 구독
    Subscription Azure 구독
    리소스 그룹 tailspin-space-game-rg
    서비스 연결 이름 Resource Manager - Tailspin - Space Game

    프로세스 중에 Microsoft 계정에 로그인하라는 프롬프트가 표시될 수 있습니다.

  7. Grant access permission to all pipelines가 선택되어 있는지 확인합니다.

  8. 저장을 선택합니다.

    Azure DevOps가 테스트 연결을 수행하여 Azure 구독에 연결할 수 있는지 확인합니다. Azure DevOps가 연결할 수 없는 경우 다시 로그인할 수 있습니다.

GitHub에서 분기 가져오기

여기에서는 GitHub으로부터 blue-green 분기를 가져옵니다. 그런 다음 해당 분기를 ‘체크 아웃’하거나 해당 분기로 전환합니다.

이 분기에는 이전 모듈에서 작업한 Space Game 프로젝트와 새로 시작할 Azure Pipelines 구성이 포함되어 있습니다.

  1. Visual Studio Code에서 통합 터미널을 엽니다.

  2. 다음 git 명령을 실행하여 Microsoft의 리포지토리에서 blue-green이라는 분기를 가져오고 해당 분기로 전환합니다.

    git fetch upstream blue-green
    git checkout -B blue-green upstream/blue-green
    

    이 명령 형식을 사용하면 upstream이라는 Microsoft GitHub 리포지토리에서 시작 코드를 가져올 수 있습니다. 잠시 후에 이 분기를 origin이라는 GitHub 리포지토리로 푸시합니다.

  3. 선택적 단계로 Visual Studio Code에서 azure-pipelines.yml을 엽니다. 초기 구성에 익숙해져야 합니다.

    구성은 이 학습 경로의 이전 모듈에서 만든 구성과 유사합니다. 이 구성은 애플리케이션의 릴리스 구성만 빌드합니다. 간단히 하기 위해 이전 모듈에서 설정한 트리거, 수동 승인, 테스트가 생략됩니다.

    학습을 위해 해당 구성은 모든 분기에서 ‘개발’, ‘테스트’, ‘스테이징’으로의 변경 사항을 승격합니다. 더 강력한 접근 방식은 릴리스 분기 또는 main의 변경 내용만 승격할 수 있습니다. Azure Pipelines를 사용하여 다단계 파이프라인 만들기 모듈에서 강력한 방법을 사용했습니다.

파이프라인을 실행하고 배포된 웹 사이트 확인하기

여기서는 초기 구성을 GitHub에 푸시하여 팀과 최신 정보를 공유합니다. 나중에 파란색-녹색 배포를 구현할 수 있도록 스테이징 환경에 슬롯을 추가합니다.

  1. Visual Studio Code에서 통합 터미널을 엽니다.

  2. 다음 git commit 명령을 실행하여 커밋 기록에 빈 항목을 추가합니다.

    git commit --allow-empty -m "Trigger the pipeline"
    

    이 단계는 학습을 위한 단계이며, 일반적이지 않습니다. 지금 수정하지 않아도 되는 시작 코드가 제공됩니다. --allow-empty 플래그를 사용하면 다음 단계가 성공적으로 분기를 GitHub에 푸시하고 트리거를 실행할 Azure Pipelines를 트리거합니다.

    이 단계를 생략한 경우에는 다음 단계에서 실행하는 git push 명령이 아무 조치도 취하지 않습니다. 따라서 실행할 Azure Pipelines가 트리거되지 않습니다.

  3. 다음 git push 명령을 실행하여 분기를 GitHub 리포지토리에 업로드합니다.

    git push origin blue-green
    
  4. Azure Pipelines에서 빌드로 이동합니다. 그런 다음 실행되는 빌드를 추적합니다. 메시지가 표시되면 허용을 선택하여 여러 단계에 배포 권한을 부여합니다.

  5. 파이프라인 실행이 완료된 후 요약 페이지로 이동하여 파이프라인 상태를 확인합니다.

    Screenshot of Azure Pipelines that shows the completed stages.

  6. 각 단계에 해당하는 URL로 이동합니다. 웹앱은 각 환경에 배포되어야 합니다.

    Screenshot of a web browser that shows the Space Game website in the Dev environment.