演習 - Azure DevOps 環境を設定する

完了

このセクションでは、このモジュールの残りの部分を完了するために、Azure DevOps 組織が設定されていることを確認します。 また、デプロイ先の Azure App Service 環境を作成します。

システムを設定するには、次の手順を行います。

  • ユーザーを追加して、Azure DevOps が Azure サブスクリプションに接続できるようにします。
  • このモジュール用の Azure DevOps プロジェクトを設定します。
  • Azure Boards 上で、このモジュールの作業項目を Doing(実行中) 列に移動します。
  • Azure Cloud Shell の Azure CLI を使用して、Azure App Service 環境を作成します。
  • App Service 環境の名前を定義するパイプライン変数を作成します。
  • Azure Pipelines で Azure サブスクリプションに安全にアクセスできるようにするサービス接続を作成します。

Azure DevOps にユーザーを追加する

このモジュールを完了するには、自分の Azure サブスクリプションが必要です。 Azure は無料で使用開始できます。

Azure DevOps を操作するために Azure サブスクリプションは必要ありませんが、このモジュールでは Azure DevOps を使用して、Azure サブスクリプション内に存在するリソースにデプロイします。 このプロセスを簡略化するには、お使いの Azure サブスクリプションと自分の Azure DevOps 組織の両方に、同じ Microsoft アカウントを使用してサインインする必要があります。

Azure と Azure DevOps へのサインインに異なる Microsoft アカウントを使用する場合は、Azure へのサインインに使用する Microsoft アカウントで自分の DevOps 組織にユーザーを追加します。 詳細については、組織またはプロジェクトへのユーザーの追加に関する記事を参照してください。 ユーザーを追加する際、Basic アクセス レベルを選択します。

その後、Azure DevOps からサインアウトし、Azure サブスクリプションへのサインインに使用する Microsoft アカウントでもう一度サインインします。

Azure DevOps プロジェクトを取得する

ここでは、このモジュールの残りの部分を完了するために、Azure DevOps 組織が設定されていることを確認します。 開始するには、Azure DevOps にプロジェクトを作成するテンプレートを実行します。

このラーニング パスのモジュールは、Tailspin Web チームの DevOps 体験をなぞる段階的学習の一部です。 学習目的のために、各モジュールには Azure DevOps プロジェクトが関連付けられています。

テンプレートの実行

Azure DevOps 組織を設定するテンプレートを実行します。

Azure DevOps Demo Generator サイトで、以下の手順に従ってテンプレートを実行します。

  1. [サインイン] を選択して利用規約に同意します。

  2. [新しいプロジェクトの作成] ページで、Azure DevOps 組織を選択してから、「Space Game - web - Nonfunctional tests」などのプロジェクト名を入力してください。

    Screenshot for Creating a project through the Azure DevOps Demo Generator.

  3. [Yes, I want to fork this repository] (はい、このリポジトリをフォークします) を選択し、[承認する] を選択します。

  4. [プロジェクトの作成] を選択します。

    テンプレートの実行には少し時間がかかります。

  5. [プロジェクトに移動] を選択して Azure DevOps のプロジェクトに移動します。

重要

このモジュールの「Azure DevOps 環境をクリーンアップする」ページには、重要なクリーンアップ手順が含まれています。 クリーンアップによって、無料のビルド時間の浪費を抑えることができます。 このモジュールを最後まで実行しなかったとしても、クリーンアップ手順は必ず行ってください。

プロジェクトの可視性を設定する

最初は、GitHub 上の Space Game リポジトリのフォークはパブリックに設定され、Azure DevOps テンプレートによって作成されたプロジェクトはプライベートに設定されます。 GitHub 上のパブリック リポジトリには誰でもアクセスできますが、プライベート リポジトリには自分のほかに共有することを選択したユーザーのみがアクセスできます。 同様に、Azure DevOps では、パブリック プロジェクトでは認証されていないユーザーに読み取り専用アクセスを提供しますが、プライベート プロジェクトではユーザーがサービスにアクセスするにはアクセス権の付与と認証が必要です。

現時点では、このモジュールにおいてこれらの設定を変更する必要はありません。 ただし、個人のプロジェクトでは、他のユーザーに付与する可視性とアクセス権を決定する必要があります。 たとえば、プロジェクトがオープンソースの場合は、GitHub リポジトリと Azure DevOps プロジェクトの両方をパブリックにすることを選択できます。 プロジェクトが独自のものである場合は、GitHub リポジトリと Azure DevOps プロジェクトの両方をプライベートにするのが一般的です。

後で、プロジェクトに最適なオプションを決定する際に、次のリソースが役立つ場合があります。

プロジェクトをローカルで設定する

ここでは、スタート コードをダウンロードできるように、Visual Studio Code への Space Game プロジェクトの読み込み、Git の構成、リポジトリのローカルへのクローン、アップストリーム リモートの設定を行います。

注意

既にローカルで mslearn-tailspin-spacegame-web-deploy プロジェクトを設定している場合は、次のセクションに進むことができます。

統合ターミナルを開く

Visual Studio Code には、統合ターミナルが付属しています。 ここでは、ファイルの編集とコマンドラインからの操作の両方を行います。

  1. Visual Studio Code を起動します。

  2. [View] メニューで、[Terminal] を選択します。

  3. ドロップダウン リストで [Git Bash] を選択します。 慣れている Unix シェルが他にあり、そちらを使用したい場合は、代わりにそのシェルを選択します。

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

    ターミナル ウィンドウでは、システムにインストールされている任意のシェルを選択できます。 たとえば、Git Bash、PowerShell、その他のシェルを選択できます。

    ここでは、Git コマンドの実行に便利な Git for Windows に含まれる Git Bash を使用します。

    Note

    Windows で、Git Bash がオプションとして表示されない場合は、Git をインストール済みであることを確認してから、Visual Studio Code を再起動してください。

  4. cd コマンドを実行して、作業場所にするディレクトリに移動します。 ホーム ディレクトリ (~)、または必要に応じて別のディレクトリを選択します。

    cd ~
    

Git を構成する

Git と GitHub を初めて使用する場合は、最初にいくつかのコマンドを実行して、自分の ID を Git に関連付け、GitHub で認証します。 詳細については、Git の設定に関するページを参照してください。

少なくとも、次の手順を完了する必要があります。 統合ターミナルからコマンドを実行します。

  1. ユーザー名を設定します。
  2. コミット メール アドレスを設定します。
  3. GitHub パスワードをキャッシュします。

注意

GitHub で既に 2 要素認証を使用している場合は、個人用アクセス トークンを作成します。 プロンプトが表示されたら、パスワードの代わりにトークンを使用します。

アクセス トークンは、パスワードと同様に扱います。 安全な場所に保管してください。

Visual Studio Code でプロジェクトを設定する

Azure DevOps を使用してアプリケーションをビルドする」ラーニング パスでは、Git リポジトリをフォークしてからクローンしました。 リポジトリには、Space Game Web サイトのソース コードが含まれています。 フォークは Azure DevOps 内のプロジェクトに接続されており、変更を GitHub にプッシュするとビルドが実行されるようになっています。

重要

このラーニング パスでは、別の Git リポジトリ (mslearn-tailspin-spacegame-web-deploy) に切り替えます。 テンプレートを実行して Azure DevOps プロジェクトを設定したときに、プロセスによってリポジトリが自動的にフォークされました。

このパートでは、パイプライン構成を変更して構築できるように、フォークをローカルにクローンします。

フォークをローカルに複製する

ご自分の GitHub アカウントに Space Game Web プロジェクトのコピーが作成されています。 次に、コンピューターにコピーをダウンロード ("クローン") して作業できるようにします。

クローンは、フォークと同様にリポジトリのコピーです。 リポジトリをクローンしたら、変更を加え、予期したとおり機能することを確認してから、それらの変更を GitHub にアップロードすることができます。 ローカル コピーは、他の認証済みユーザーが、GitHub のご自分のリポジトリのコピーに対して行った変更と同期させることもできます。

Space Game Web プロジェクトをコンピューターにクローンするには、次のようにします。

  1. GitHub にある Space Game Web プロジェクト (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 上のリポジトリが明示されています。 別のリポジトリからコードをフォークする場合は、元のリモート (フォーク元) に「upstream」という名前を付けるのが一般的です。

  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 Web プロジェクトのルート ディレクトリを指し示しています。 その構造を表示し、ファイルを操作するには、ファイル エクスプローラーから、ここでプロジェクトを開きます。

  1. プロジェクトを開く最も簡単な方法は、現在のディレクトリで Visual Studio Code を再度開くことです。 これを行うには、統合ターミナルから次のコマンドを実行します。

    code -r .
    

    エクスプローラーでディレクトリとファイル ツリーを確認します。

  2. 統合ターミナルをもう一度開きます。 ターミナルでは、ご使用の Web プロジェクトのルートに表示されます。

code コマンドが失敗した場合は、ご使用のシステム PATH に Visual Studio Code を追加する必要があります。 そのためには次を行います。

  1. Visual Studio Code で、[F1] を選択するか、[表示]>[コマンド パレット] を選択して、コマンド パレットにアクセスします。
  2. コマンド パレットで、「シェル コマンド:PATH 内に 'code' コマンドをインストールします」と入力します。
  3. 前の手順を繰り返して、ファイル エクスプローラーでプロジェクトを開きます。

これで、Space Game のソース コードと Azure Pipelines 構成をローカル開発環境から操作できるように設定されました。

Azure App Service 環境を作成する

ここでは、パイプラインのステージを定義する環境を作成します。 次の各ステージに対応する App Service インスタンスを 1 つ作成します:"開発"、"テスト"、"ステージング" の各ステージにデプロイします。

以前のモジュールでは、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. 出力の Name 列から、最寄りのリージョンを選択します。 たとえば、eastasiawestus2 を選択します。

  3. az configure を実行して、自分の既定のリージョンを設定します。 <[リージョン]> を、選択したリージョンの名前に置き換えます。

    az configure --defaults location=<REGION>
    

    westus2 を既定のリージョンとして設定する例を次に示します。

    az configure --defaults location=westus2
    

App Service インスタンスを作成する

ここでは、デプロイする次の 3 つのステージの App Service インスタンスを作成します:"開発"、"テスト"、"ステージング" の各ステージにデプロイします。

Note

学習の目的で、既定のネットワーク設定を使用します。 これらの設定により、インターネットからサイトにアクセスできるようになります。 実際には、インターネットからはルーティングできず、自分のチームだけがアクセスできるネットワークに Web サイトを配置する Azure 仮想ネットワークを構成できます。 後で準備ができたら、ネットワークを再構成して、ユーザーが Web サイトを利用できるようにすることができます。

  1. Cloud Shell で、Web アプリのドメイン名を一意にするランダムな数値を生成します。

    webappsuffix=$RANDOM
    
  2. 次の az group create コマンドを実行して、tailspin-space-game-rg という名前のリソース グループを作成します。

    az group create --name tailspin-space-game-rg
    
  3. 次の az appservice plan create コマンドを実行して、tailspin-space-game-asp という名前の App Service プランを作成します。

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

    --sku 引数は、Basic サービス レベルで実行される B1 プランを指定します。 --is-linux 引数では、Linux ワーカーを使用するよう指定しています。

    重要

    B1 SKU がお使いの Azure サブスクリプションの一部として使用できない場合、S1 (Standard) など、別のプランを選択します

  4. 以下の az webapp create コマンドを実行し、"開発"、"テスト"、"ステージング" の各環境用に 1 つずつ、3 つの App Service インスタンスを作成します。

    az webapp create \
      --name tailspin-space-game-web-dev-$webappsuffix \
      --resource-group tailspin-space-game-rg \
      --plan tailspin-space-game-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-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-asp \
      --runtime "DOTNET|6.0"
    

    学習目的のため、ここでは、各 App Service インスタンスに同じ App Service プラン (B1 Basic) を適用します。 実際は、予測されるワークロードに一致するプランを割り当てます。

  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. 省略可能な手順として、1 つ以上の一覧表示された名前に移動して、それらが実行されていることと、既定のホーム ページが表示されていることを確認します。

    次のページが表示されます。

    Screenshot of the default home page on Azure App Service.

重要

このモジュールの「Azure DevOps 環境をクリーンアップする」ページには、重要なクリーンアップ手順が含まれています。 クリーンアップは、このモジュールを完了した後に Azure リソースに対して課金されないようにするために役立ちます。 クリーンアップ手順は、このモジュールを完了しなかった場合でも必ず行ってください。

Azure Pipelines でパイプライン変数を作成する

Azure Pipelines で機能テストを実行する」では、App Service インスタンスごとに 1 つの変数を追加しました。 これらのインスタンスは、パイプラインの "開発"、"テスト"、"ステージング" の各ステージに対応します。 ここでは、同じパターンに従います。

パイプライン構成内の各ステージでは、この変数を使用して、デプロイ先の App Service インスタンスを識別します。

変数を追加するには、次の手順に従います。

  1. Azure DevOps で、Space Game - web - Nonfunctional tests プロジェクトにアクセスします。

  2. [パイプライン][ライブラリ] を選択します。

    Screenshot of Azure Pipelines, showing the Library menu option.

  3. [+ Variable group] を選択します。

  4. [プロパティ] の変数グループ名に「Release」と入力します。

  5. [変数][+ 追加] を選択します。

  6. 変数の名前として「WebAppNameDev」を入力します。 その値として、"開発" 環境に対応する App Service インスタンスの名前 (tailspin-space-game-web-dev-1234 など) を入力します。

  7. 次の表に示すように、手順 5 と 6 をさらに 2 回繰り返して、"テスト" と "ステージング" の環境用の変数を作成します。

    変数名 値の例
    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, showing the variable group. The group contains three variables.

dev 環境、test 環境、staging 環境を作成する

Azure Pipelines で機能テストを実行する」では、開発テストステージングの各環境を作成しました。 ここでは、このプロセスを繰り返します。

devteststaging の各環境を作成するには:

  1. Azure Pipelines で、[Environments] を選択します。

    Screenshot of Azure Pipelines showing the location of the Environments menu option.

  2. dev 環境を作成するには:

    1. [環境の作成] を選択します。
    2. [名前] に「dev」と入力します。
    3. 残りのフィールドは既定値のままにします。
    4. [作成] を選択します
  3. test 環境を作成するには:

    1. [環境] ページに戻ります。
    2. [New environment] (新しい環境) を選択します。
    3. [名前] に「test」と入力します。
    4. [作成] を選択します。
  4. ステージング環境を作成するには、次の手順を実行します。

    1. [環境] ページに戻ります。
    2. [New environment] (新しい環境) を選択します。
    3. [Name] に "ステージング" と入力します。
    4. [作成] を選択します。

サービス接続を作成する

ここでは、Azure Pipelines で Azure サブスクリプションにアクセスできるようにするサービス接続を作成します。 Azure Pipelines では、このサービス接続を使用して Web サイトを App Service にデプロイします。 前のモジュールで同様のサービス接続を作成しました。

重要

同じ Microsoft アカウントで Azure portal と Azure DevOps の両方にサインインしていることを確認してください。

  1. Azure DevOps で、Space Game - web - Nonfunctional tests プロジェクトにアクセスします。

  2. ページの下隅で、[プロジェクトの設定] を選択します。

  3. [パイプライン] で、[サービス接続] を選択します。

  4. [新しいサービス接続][Azure Resource Manager] と選択してから、[次へ] を選択します。

  5. ページ最上部の近くにある [サービス プリンシパル (自動)] を選択します。 [次へ] を選択します。

  6. 以下のフィールドを設定します。

    フィールド
    スコープのレベル サブスクリプション
    サブスクリプション お使いの Azure サブスクリプション
    リソース グループ tailspin-space-game-rg
    サービス接続名 Resource Manager - Tailspin - Space Game

    処理中に、Microsoft アカウントにサインインするように求められる場合があります。

  7. 必ず、[すべてのパイプラインへのアクセス許可を与える] を選択してください。

  8. [保存] を選択します。

    Azure サブスクリプションに接続できることを確認するために、Azure DevOps でテスト接続が実行されます。 Azure DevOps で接続できない場合は、もう一度サインインする機会があります。