Azure DevTest Labs でのアイテム保持ポリシーの設定
この記事では、保持ポリシーの設定、ファクトリのクリーンアップ、および組織内の他のすべての DevTest Labs からの古いイメージの回収を取り上げます。
前提条件
先に進む前に以下の記事に従っていることを確認してください:
次の項目が既に配置されている必要があります。
- Azure DevTest Labs のイメージ ファクトリ用のラボ
- ファクトリがゴールデン イメージを配布する 1 つ以上のターゲット Azure DevTest Labs
- イメージ ファクトリを自動化するために使用される Azure DevOps プロジェクト。
- スクリプトと構成を含むソース コードの場所 (この例では、上記の同じ DevOps プロジェクト内)
- Azure Powershell タスクを調整するためのビルド定義
保持ポリシーの設定
クリーンアップの手順を構成する前に、DevTest Labs で保持したい履歴イメージの数を定義します。 「Azure DevOps からイメージ ファクトリを実行する」の記事に従っていれば、さまざまなビルド変数を構成しています。 その 1 つが ImageRetention でした。 この変数を 1
に設定します。これは、DevTest Labs がカスタム イメージの履歴を保持しないことを意味します。 最新の配布イメージだけを使用できます。 この変数を 2
に変更すると、最新の配布イメージと以前のイメージが保持されます。 この値を設定して、DevTest Labs で保持したい履歴イメージの数を定義できます。
ファクトリのクリーンアップ
ファクトリのクリーンアップでは最初に、イメージ ファクトリからゴールデン イメージ VM を削除します。 以前のスクリプトと同様に、このタスクを実行するスクリプトがあります。 最初の手順として、次の図に示すように、別の Azure Powershell タスクをビルド定義に追加します:
一覧に新しいタスクが追加されたら、その項目を選択し、次の図に示すようにすべての詳細を入力します。
スクリプト パラメーターは -DevTestLabName $(devTestLabName)
です。
古いイメージを回収する
このタスクは、すべての古いイメージを削除し、ImageRetention ビルド変数に一致する履歴だけを保持します。 別の Azure Powershell ビルド タスクをビルド定義に追加します。 追加されたら、タスクを選択し、次の図のように詳細を入力します。
スクリプト パラメーターは -ConfigurationLocation $(System.DefaultWorkingDirectory)$(ConfigurationLocation) -SubscriptionId $(SubscriptionId) -DevTestLabName $(devTestLabName) -ImagesToSave $(ImageRetention)
です。
ビルドをキューに配置する
ビルド定義を完了したので、新しいビルドをキューに追加し、すべてが機能していることを確認します。 ビルドが正常に完了すると、新しいカスタム イメージが送信先のラボに表示されます。 イメージ ファクトリ ラボを見てみると、プロビジョニングされた VM は表示されません。 さらにビルドをキューに追加すると、DevTest Labs から古いカスタム イメージを削除するクリーンアップ タスクが表示されます。 削除はビルド変数に設定されている保有期間の値に従って行われます。
Note
一連の処理の最後にビルド パイプラインを実行した場合は、新しいビルドをキューに配置する前にイメージ ファクトリ ラボで作成した仮想マシンを手動で削除してください。 手動でのクリーンアップ手順は、すべてのものをセットアップして正しく動作することを確認するときにのみ必要となります。
まとめ
これで、必要に応じてカスタム イメージを生成してラボに配布できる実行中イメージ ファクトリが用意されました。 この時点では、イメージを正しく設定し、ターゲット ラボを特定するだけです。 前の記事で説明したように、自身の Configuration フォルダーに置かれている Labs.json ファイルは、ターゲット ラボのそれぞれで使用可能にする必要のあるイメージを指定します。 組織に他の DevTest Labs を追加するときに、新しいラボに対して Labs.json 内のエントリを追加する必要があるだけです。
ファクトリへの新しいイメージの追加も簡単です。 ファクトリに新しいイメージを含めたいときは、Azure portal を開き、ファクトリ ラボに進んでください。 VM を追加するボタンを選択し、必要なマーケットプレース イメージとビルド成果物を選択します。 [作成] ボタンを選択して新しい VM を作成する代わりに、 [Azure Resource Manager テンプレートを見る] を選択します。 テンプレートをリポジトリの GoldenImages フォルダー内のどこかに .json ファイルとして保存します。 次回、イメージ ファクトリを実行するときに、カスタム イメージが作成されます。
次のステップ
- イメージ ファクトリを定期的に実行するようにビルド/リリースのスケジュールを設定します。 ファクトリによって生成されたイメージを定期的に更新します。
- ファクトリのより多くのゴールデン イメージを作成します。 また、ビルド成果物を作り、VM セットアップ タスクのより多くの部分をスクリプト化し、その成果物をファクトリ イメージに含めることを検討することもできます。
- 別々のビルド/リリースを作成して、DistributeImages スクリプトを別々に実行します。 Labs.json に変更を加え、ターゲット ラボにイメージをコピーするときに、このスクリプトを実行でき、すべてのイメージを再作成する必要はありません。