コードのデプロイ deploy-your-code

AEM as a Cloud Service の Cloud Manager パイプラインを使用して、コードを実稼動環境にデプロイする方法を説明します。

実稼働パイプラインのダイアグラム

コードをステージング環境に、さらには実稼動環境にシームレスにデプロイするには、実稼動パイプラインを使用します。実稼動パイプラインの実行は、2 つの論理フェーズに分かれます。

  1. ステージング環境へのデプロイメント
    • コードはビルドされたあと、ステージング環境にデプロイされて、自動化された機能テスト、UI テスト、エクスペリエンス監査、ユーザー受け入れテスト(UAT)が実施されます。
  2. 実稼動環境へのデプロイメント
    • ビルドがステージング環境で検証され、実稼動環境への昇格が承認されると、同じビルドアーティファクトが実稼動環境にデプロイされます。

コードスキャン、機能テスト、UI テスト、エクスペリエンス監査をサポートしているのは、フルスタックコードパイプラインタイプのみです。

AEM as a Cloud Service の Cloud Manager を使用したコードのデプロイ deploying-code-with-cloud-manager

リポジトリー、環境およびテスト環境を含め、実稼動パイプラインを設定したら、コードをデプロイする準備が整います。

  1. my.cloudmanager.adobe.com で Cloud Manager にログインし、適切な組織を選択します。

  2. マイプログラム ​画面で、コードをデプロイするプログラムをタップまたはクリックします。

  3. 概要 ​画面でコールトゥアクションの「デプロイ」をクリックして、デプロイメントプロセスを開始します。

    CTA

  4. パイプライン実行 ​画面が表示されます。「ビルド」をクリックしてプロセスを開始します。

    パイプライン実行画面

ビルドプロセスでは、次の 3 つのフェーズを経てコードがデプロイされます。

TIP
テスト条件のログを表示したり、結果を確認したりすることで、様々なデプロイメントプロセスから手順を確認できます。

ステージデプロイメントフェーズ stage-deployment

ステージデプロイメント ​フェーズには、以下のステップが含まれます。

  • 検証 - このステップでは、現在使用可能なリソースを使用するようにパイプラインが設定されていることを確認します。例えば、設定済みのブランチが存在し、環境が使用可能であることをテストします。
  • ビルドテストとユニットテスト - このステップでは、コンテナ化されたビルドプロセスを実行します。
  • コードスキャン - このステップでは、アプリケーションコードの品質を評価します。
  • ビルドイメージ - このプロセスでは、ビルドステップで生成されたコンテンツおよび Dispatcher パッケージを Docker イメージと Kubernetes 設定に変換します。
  • ステージにデプロイ - ステージテストフェーズに備えて、イメージがステージング環境にデプロイされます。

ステージデプロイメント

ステージテストフェーズ stage-testing

ステージテスト ​フェーズには、以下のステップが含まれます。

  • 製品機能テスト - ステージング環境に照らして実行されるテストを Cloud Manager パイプラインで実行します。

  • カスタム機能テスト - パイプラインのこのステップは常に実行され、スキップできません。ビルドでテスト JAR が生成されない場合、テストはデフォルトで合格します。

  • カスタム UI テスト - このステップは、カスタムアプリケーション用に作成された UI テストを自動的に実行するオプション機能です。

    • UI テストは、言語とフレームワークの幅広い選択肢(Java と Maven、Node と WebDriver.io、Selenium に基づいて構築されたその他のフレームワークとテクノロジーなど)を可能にするために Docker イメージにパッケージ化された Selenium ベースのテストです。
    • 詳しくは、カスタム UI テストを参照してください。
  • エクスペリエンス監査 - パイプラインのこのステップは常に実行され、スキップできません。実稼動パイプラインの実行時に、チェックを実行するカスタム機能テストの後に、エクスペリエンス監査ステップが組み込まれます。

    • 設定されたページがサービスに送信され、評価されます。
    • 結果は情報提供であり、スコアおよび現在のスコアと以前のスコア間の変化を示します。
    • このインサイトは、現在のデプロイメントでリグレッションが導入されいないか判断するのに役立ちます。
    • 詳しくは、エクスペリエンス監査結果についてを参照してください。

ステージテスト

実稼動デプロイメントフェーズ deployment-production

AEM サイト訪問者への影響を最小限に抑えるために、実稼動トポロジへのデプロイプロセスはわずかに異なります。

実稼動デプロイメントは、通常、前述と同じステップに従いますが、周期的な方法で実行されます。

  1. オーサーに AEM パッケージをデプロイします。
  2. dispatcher1 をロードバランサーから分離します。
  3. AEM パッケージを publish1 にデプロイし、Dispatcher を dispatcher1 にデプロイして、Dispatcher キャッシュをフラッシュします。
  4. dispatcher1 をロードバランサーに戻します。
  5. dispatcher1 がサービスを再開したら、dispatcher2 をロードバランサーから分離します。
  6. AEM パッケージを publish2 にデプロイし、Dispatcher パッケージを dispatcher2 にデプロイして、Dispatcher キャッシュをフラッシュします。
  7. dispatcher2 をロードバランサーに戻します。

このプロセスは、デプロイメントがトポロジのすべてのパブリッシャーおよび Dispatcher に到達するまで続行されます。

実稼動デプロイメントフェーズ

タイムアウト timeouts

ユーザーのフィードバックを待機したままにすると、次の手順はタイムアウトします。

ステップ
タイムアウト
コード品質テスト
14 日
セキュリティテスト
14 日
パフォーマンステスト
14 日
アプリケーションの承認
14 日
実稼動デプロイメントをスケジュール
14 日
CSE サポート
14 日

デプロイメントプロセス deployment-process

Cloud Service のすべてのデプロイメントでは、ダウンタイムをなくすために、ローリングプロセスに従います。詳しくは、ローリングデプロイメントの仕組みを参照してください。

NOTE
Dispatcher のキャッシュは、デプロイメントのたびに消去されます。その後、新しいパブリッシュノードがトラフィックを受け入れる前にウォームアップされます。

実稼動デプロイメントの再実行 reexecute-deployment

まれに、一時的な理由で実稼動デプロイメントステップが失敗すること場合があります。このような場合、実稼動デプロイメントステップの再実行は、完了のタイプ(キャンセル、失敗など)に関係なく、実稼動デプロイメントステップが完了している限りサポートされます。再実行の場合は、3 つのステップで構成される同じパイプラインを使用して新しい実行が作成されます。

  1. 検証ステップ - 通常のパイプライン実行時に行われる検証と基本的に同じです。
  2. ビルドステップ - 再実行のコンテキストでは、ビルドステップは、新しいビルドプロセスを実際に実行するのではなく、アーティファクトをコピーします。
  3. 実稼動デプロイメントステップ - 通常のパイプライン実行における実稼動デプロイメントステップと同じ設定およびオプションを使用します。

再実行が可能な状況では、実稼動パイプラインステータスページには、通常の「ビルドログをダウンロード」オプションの横に「再実行」オプションが表示されます。

パイプラインの概要ウィンドウの「再実行」オプション

NOTE
再実行の場合、ビルドステップには UI でラベルが付けられて、アーティファクトを再ビルドではなくコピーしていることが示されます。

制限事項 limitations

  • 実稼動デプロイメントステップの再実行は、最後の実行に対してのみ使用できます。
  • プッシュ更新実行に対しては、再実行を使用できません。
    • 最後の実行がプッシュ更新実行の場合、再実行はできません。
  • 実稼動デプロイメントステップより前の任意の時点で最後の実行が失敗した場合、再実行はできません。

再実行 API reexecute-API

UI で使用できるだけでなく、Cloud Manager API を使用して再実行をトリガーしたり、再実行としてトリガーされた実行を識別したりすることもできます。

再実行のトリガー reexecute-deployment-api

再実行をトリガーするには、実稼動デプロイメントステップの状態で HAL リンク(https://ns.adobe.com/adobecloud/rel/pipeline/reExecute)に対して PUT リクエストを行います。

  • このリンクが存在する場合は、そのステップから実行を再開できます。
  • 存在しない場合は、そのステップから実行を再開することはできません。

このリンクは、実稼動デプロイメントステップでのみ使用できます。

 {
  "_links": {
    "https://ns.adobe.com/adobecloud/rel/pipeline/logs": {
      "href": "/api/program/4/pipeline/1/execution/953671/phase/1575676/step/2983530/logs",
      "templated": false
    },
    "https://ns.adobe.com/adobecloud/rel/pipeline/reExecute": {
      "href": "/api/program/4/pipeline/1/execution?stepId=2983530",
      "templated": false
    },
    "https://ns.adobe.com/adobecloud/rel/pipeline/metrics": {
      "href": "/api/program/4/pipeline/1/execution/953671/phase/1575676/step/2983530/metrics",
      "templated": false
    },
    "self": {
      "href": "/api/program/4/pipeline/1/execution/953671/phase/1575676/step/2983530",
      "templated": false
    }
  },
  "id": "6187842",
  "stepId": "2983530",
  "phaseId": "1575676",
  "action": "deploy",
  "environment": "weretail-global-b75-prod",
  "environmentType": "prod",
  "environmentId": "59254",
  "startedAt": "2022-01-20T14:47:41.247+0000",
  "finishedAt": "2022-01-20T15:06:19.885+0000",
  "updatedAt": "2022-01-20T15:06:20.803+0000",
  "details": {
  },
  "status": "FINISHED"

HAL リンクの href 値の構文は一例に過ぎません。実際の値は、常に HAL リンクから読み取られるべきものであり、生成されるものではありません。

このエンドポイントに PUT リクエストを送信すると、成功の場合は 201 応答が返され、新しい実行の表現が応答の本文になります。これは、API を使用して通常の実行を開始する場合と似ています。

再実行された実行の識別 identify-reexecution

再実行された実行は、trigger フィールドの値 RE_EXECUTE によって識別できます。

recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab