Azure Container Apps の変更を更新してデプロイする
- [アーティクル]
-
-
クラウドでコンテナー化されたアプリケーションを開発する場合、変更管理は困難な場合があります。 最終的には、変更を追跡し、アップタイムを確保し、スムーズなロールバックを処理するメカニズムを備えるサポートが必要です。
Azure Container Apps での変更管理には、コンテナー アプリの各バージョンのスナップショットであるリビジョンによって強化されています。
リビジョンの主な特性は次のとおりです。
不変: 確立されると、リビジョンは変更できません。
バージョン管理: リビジョンは、コンテナー アプリのバージョンのレコードとして機能し、さまざまな段階でその状態をキャプチャします。
自動プロビジョニング: コンテナー アプリを初めてデプロイすると、初期リビジョンが自動的に作成されます。
スコープの変更: リビジョンは静的なままですが、アプリケーション スコープの変更はすべてのリビジョンに影響する可能性があります。一方、リビジョン スコープの変更により、新しいリビジョンが作成されます。
履歴レコード: 既定では、100 個の非アクティブなリビジョンにアクセスできますが、このしきい値は手動で調整できます。
複数のリビジョン: 複数のリビジョンを同時に実行できます。 この機能は、異なるバージョンのアプリを同時に管理する必要がある場合に特に便利です。
各リビジョンは、その状態と可用性の影響を受け、特定の状態になります。 コンテナー アプリは、そのライフサイクル中に、異なるプロビジョニング、実行中、非アクティブ状態を経ます。
新しいリビジョンを作成すると、コンテナー アプリは起動と準備のチェックを受けます。 このフェーズでは、プロビジョニングの状態が、コンテナー アプリの進行状況を追跡するためのガイドとして機能します。
Status |
説明 |
プロビジョニング |
リビジョンは検証プロセス中です。 |
プロビジョニング済み |
リビジョンはすべてのチェックに合格しました。 |
"プロビジョニング失敗" |
検証中にリビジョンで問題が発生しました。 |
コンテナー アプリが正常にプロビジョニングされると、リビジョンは動作フェーズに入ります。 実行中の状態は、コンテナー アプリの正常性と機能を監視するのに役立ちます。
Status |
説明 |
プロビジョニング |
リビジョンは検証プロセス中です。 |
0 にスケーリングする |
レプリカを実行せず、新しいレプリカをプロビジョニングしません。 スケール ルールがトリガーされた場合、コンテナー アプリは新しいレプリカを作成できます。 |
アクティブ化中 |
レプリカを実行せず、1 つのレプリカがプロビジョニングされています。 |
アクティブ化に失敗しました |
最初のレプリカのプロビジョニングに失敗しました。 |
スケーリング/処理 |
スケールインまたはスケールアウトが行われています。 1 つ以上のレプリカが実行されている間に、他のレプリカがプロビジョニングされています。 |
実行中 |
1 つ以上のレプリカが実行されています。 報告する問題はありません。 |
実行中 (最大) |
最大数のレプリカ (リビジョンのスケール ルールに従って) が実行されています。 報告する問題はありません。 |
Deprovisioning |
リビジョンがアクティブから非アクティブに移行しており、作成したリソースが削除されています。 |
低下しています |
リビジョン内の少なくとも 1 つのレプリカが失敗状態です。 特定の問題の実行中の状態の詳細を表示します。 |
Failed |
重大なエラーにより、リビジョンは失敗しました。 "実行状態" で詳細が提供されます。 一般的な原因には、次のようなものがあります。 • 終了 • 終了コード 137 |
リビジョンは非アクティブな状態になる場合もあります。 これらのリビジョンには、プロビジョニングまたは実行中の状態はありません。 ただし、Azure Container Apps では、これらのリビジョンの一覧が保持され、最大 100 個の非アクティブなエントリに対応できます。 リビジョンはいつでもアクティブ化できます。
パラメーターとコマンドを --max-inactive-revisions
containerapp create
containerapp update
使用して、Container Apps によって追跡される非アクティブなリビジョンの数を制御できます。
この例では、50 個の非アクティブなリビジョンを追跡する新しいコンテナー アプリを作成する方法を示します。
az containerapp create --max-inactive-revisions 50
Azure Container Apps では、2 つのリビジョン モードがサポートされています。 モードを選択すると、同時にアクティブになっているアプリのリビジョンの数が決まります。
リビジョン モード |
説明 |
Default |
単一 |
新しいリビジョンは、自動的にプロビジョニングされ、アクティブ化され、目的のサイズにスケーリングされます。 スケール ルールで定義されているすべてのレプリカが実行されると、トラフィックは古いバージョンから新しいバージョンに転送されます。 更新に失敗した場合、トラフィックは古いリビジョンを指したままになります。 古いリビジョンは自動的にプロビジョニング解除されます。 |
はい |
複数 |
複数のアクティブなリビジョンを設定したり、リビジョン間でトラフィックを分割したり、古いリビジョンのプロビジョニングを解除するタイミングを選択したりできます。 このレベルの制御は、アプリの複数のバージョンのテスト、ブルーグリーン テスト、またはアプリの更新プログラムの完全な制御に役立ちます。 詳細については、「トラフィック分割」を参照してください。 |
|
外部 HTTP トラフィックを含むコンテナー アプリの場合、ラベルはトラフィックを特定のリビジョンに転送します。 ラベルによって、ラベルが割り当てられているリビジョンにトラフィックをルーティングするために使用できる一意の URL が提供されます。
リビジョン間でトラフィックを切り替えるには、あるリビジョンから別のリビジョンにラベルを移動します。
- ラベルは、あるリビジョンから別のリビジョンに移動されても、同じ URL を保持します。
- ラベルは、一度に 1 つのリビジョンにのみ適用できます。
- ラベルを含むリビジョンでは、トラフィック分割の割り当ては必要ありません。
- ラベルは、アプリが "複数リビジョン" モードの場合に最も有用です。
- ラベル、トラフィック分割、またはその両方を有効にできます。
ラベルは、新しいリビジョンをテストするのに役立ちます。 たとえば、一連のテスト ユーザーにアクセス権を付与する場合、ラベルの URL を通知できます。 その後、ユーザーを別のリビジョンに移動する場合は、そのリビジョンにラベルを移動できます。
ラベルは、トラフィック分割とは独立して機能します。 トラフィック分割では、トラフィックの割合に基づいて、コンテナー アプリのアプリケーション URL に送信されるトラフィックがリビジョンに振り分けられます。 トラフィックがラベルの URL に誘導されると、このトラフィックは 1 つの特定のリビジョンにルーティングされます。
ラベル名は次の条件を満たしている必要があります。
- 小文字の英数字またはダッシュ (
-
) で構成される
- 英字で始まる
- 英数字で終わる
ラベルは次の条件を満たしてはなりません。
- 2 つの連続したダッシュ (
--
) がある
- 64 文字を超える
ラベルは、Azure portal のコンテナー アプリの [リビジョン管理] ページから管理できます。
ラベル URL は、リビジョンの詳細ウィンドウで使用できます。
単一リビジョン モードでは、Container Apps によって、新しいリビジョンを作成するときにアプリにダウンタイムが発生しないように設定されます。 既存のアクティブなリビジョンは、新しいリビジョンの準備ができるまで非アクティブ化されません。
イングレスが有効になっている場合、新しいリビジョンの準備ができるまで、既存のリビジョンはトラフィックの 100% を引き続き受信します。
新しいリビジョンは、次の場合に準備ができていると見なされます。
- リビジョンが正常にプロビジョニングされました
- リビジョンは、以前のリビジョンのレプリカ数に合わせてスケールアップされました (新しいリビジョンの最小レプリカ数と最大レプリカ数を考慮)
- すべてのレプリカが起動プローブと準備プローブに合格しました
複数リビジョン モードでは、リビジョンをアクティブ化または非アクティブ化するタイミングと、イングレス トラフィックを受信するリビジョンを制御できます。 を に設定してlatestRevision
トラフィック分割ルールtrue
が構成されている場合、準備ができるまでトラフィックは最新のリビジョンに切り替わりません。
単一リビジョン モードが既定ですが、リビジョンの管理方法を完全に制御したい場合があります。
複数リビジョン モードを使用すると、リビジョンを手動で柔軟に管理できます。 たとえば、複数リビジョン モードを使用すると、各リビジョンに割り当てられるトラフィックの量を正確に決定できます。
次の図は、2 つのリビジョンを持つコンテナー アプリを示しています。
このシナリオでは、コンテナー アプリが次の状態であることが想定されています。
- イングレスが有効になっており、コンテナー アプリは HTTP または TCP 経由で利用できます。
- 最初のリビジョンは、"リビジョン 1" としてデプロイされました。
- コンテナーが更新された後、新しいリビジョンが "リビジョン 2" としてアクティブ化されました。
- トラフィックの分割ルールは、"リビジョン 1" が要求の 80% を受信し、"リビジョン 2" が残りの 20% を受信するように構成されています。
ルーティング規則を使用してトラフィックをリビジョンに転送するのではなく、特定の URL の要求でリビジョンを使用できるようにする必要がある場合があります。 複数リビジョン モードを使用すると、ドメインに入ってくるすべての要求を最新のリビジョンに送信できますが、古いリビジョンの要求は直接アクセスの ラベルを介して使用できます。
複数リビジョン モードでは、必要に応じてリビジョンをアクティブ化または非アクティブ化できます。 アクティブなリビジョンは運用可能であり、要求を処理できますが、非アクティブなリビジョンは休止状態のままです。
Container Apps は、非アクティブなリビジョンに対して課金されません。 ただし、使用可能なリビジョンの合計数には上限があり、最も古いものは 100 を超えると消去されます。
コンテナー アプリに加えられた変更は、"リビジョンスコープ" または "アプリケーションスコープ" の変更の 2 つのカテゴリに分類されます。 アプリをデプロイするときに、"リビジョンスコープ" の変更では新しいリビジョンがトリガーされ、"アプリケーションスコープ" の変更ではトリガーされません。
新しいリビジョンは、コンテナー アプリが "リビジョンスコープ" の変更で更新されると、作成されます。 変更はデプロイされているリビジョンに限定され、他のリビジョンには影響しません。
"リビジョンスコープ" の変更とは、コンテナー アプリ リソース テンプレートの properties.template
セクションのパラメーターに対するあらゆる変更です。
これらのパラメーターには、以下のものがあります。
"アプリケーションスコープ" が変更されたコンテナー アプリをデプロイする場合、次のようになります。
- 変更はすべてのリビジョンにグローバルに適用されます。
- 新しいリビジョンは作成されません。
"アプリケーションスコープ" の変更は、コンテナー アプリ リソース テンプレートの properties.configuration
セクションのパラメーターに対するあらゆる変更と定義されます。
これらのパラメーターには、以下のものがあります。
- シークレット値 (コンテナーが新しいシークレット値を認識する前にリビジョンを再起動する必要があります)
- リビジョン モード
- 以下を含むイングレス構成:
- プライベート コンテナー レジストリの資格情報
- Dapr 設定
リビジョン名とラベルをカスタマイズして、名前付け規則やバージョン管理戦略に合わせて調整できます。
Container Apps のすべてのリビジョンには、一意識別子が割り当てられます。 名前は自動的に生成されますが、リビジョン名をカスタマイズできます。
リビジョン名の一般的な形式は次のとおりです。
<CONTAINER_APP_NAME>-<REVISION_SUFFIX>
たとえば、album-api という名前のコンテナー アプリがあり、リビジョン サフィックス first-revision を決定した場合、完全なリビジョン名はalbum-api-first-revision になります。
リビジョン サフィックス名は次の条件を満たす必要があります。
- 小文字の英数字またはダッシュ (
-
) のみで構成される
- 英字で始まる
- 英数字で終わる
名前は次の条件を満たしてはなりません。
- 2 つの連続するダッシュ (
--
)
- 64 文字を超える
リビジョン サフィックスは、ARM テンプレートで、Azure CLI の az containerapp create
および az containerapp update
コマンドを使用して、または Azure portal からリビジョンを作成するときに設定できます。
コンテナー アプリでリビジョンを使用する一般的なユース ケースを次に示します。 この一覧は、Container Apps リビジョンを使用する目的や機能を網羅した一覧ではありません。
リビジョンにより、新しいバージョンのアプリを導入するプロセスが効率化されます。 更新プログラムまたは新機能をロールアウトする準備ができたら、現在のライブ バージョンに影響を与えずに新しいリビジョンを作成できます。 このアプローチにより、スムーズな移行が保証され、エンド ユーザーの中断が最小限に抑えられます。
以前の安定したバージョンのアプリにすばやく戻す必要がある場合があります。 必要に応じて、コンテナー アプリの以前のリビジョンにロールバックできます。
異なるバージョンのアプリをテストする場合、リビジョンは A/B テストをサポートできます。 ユーザーのサブセットを新しいリビジョンにルーティングし、フィードバックを収集し、実際のデータと情報に基づいて意思決定を行うことができます。
リビジョンでは、ブルーグリーン デプロイ戦略 がサポートされています。 2 つの並列リビジョン (ライブ バージョンの場合は青、新しいバージョンの場合は緑) を使用することで、新しいリビジョンを段階的にフェーズ化できます。 新しいバージョンの安定性とパフォーマンスに自信を持てたら、トラフィックをグリーン環境に完全に切り替えることができます。