主要なユーザー フローに基づいてロード テストを定義する

完了

ロード テストは、継続的な検証の重要な部分です。 開始するには、アプリケーション フローを識別する必要があります。 このユニットでは、ユーザー フローとシステム フロー、それらが重要な理由、テストの設計基準について学習します。

アプリケーション フローとは

フローは、タスクを完了するために必要なアプリケーション対話式操作で構成されます。

  • ユーザー フロー

    これらのフローは、ユーザーがアプリケーションと対話する方法を示します。 Contoso Shoes のシナリオでは、品目を購入するためのチェックアウト プロセスがユーザー フローの例です。 次のコンポーネントが、在庫管理に関わります。

    • フロント エンドの Web アプリケーション
    • Azure Functions のチェックアウト ロジック
    • Azure Cosmos DB のバックエンド データベース

    ミッション クリティカルな観点から見ると、これらのコンポーネントは高い可用性と、障害に対する回復性が必要です。 たとえば、この組織は多数の同時ユーザーを想定しているため、フロントエンド Web ページを迅速に読み込む必要があります。

  • システム フロー

    通常、これらのフローはユーザーの目に触れることはありませんが、システム フロー コンポーネントの停止や低下はユーザー エクスペリエンスに影響を与える可能性があります。 ユーザー フローとしては、たとえば、データベースから注文を取得し、出荷ラベルを生成する非同期アクティビティなどが考えられます。

Note

ほとんどのアプリケーションには複数のフローがあります。 各フローは、アーキテクチャのさまざまなコンポーネントに接することがあります。 また、1 つのコンポーネントが複数のフローに表示されることがあります。 コンポーネントに障害が発生したときに影響を受けるフローを理解することが重要です。

ロード テストとそのしきい値を定義する

ロード テストでは、実際のトラフィックをシミュレートして、アプリケーションのパフォーマンスをテストします。 ただし、その目標は、システムを壊すために大きな負荷を生成することではありません。 その目標は、ストレス テストを通じて達成できます。

ロード テストは、ユーザー フローのコンポーネントのパフォーマンス、パフォーマンス制限、リソース使用率、最適なスケーリング動作を特定するのに役立ちます。 ロード テストには、関連するすべてのユーザー フローとシステム フローが反映されている必要があります。 適切な設計には、アプリケーションに関する知識が必要です。 まず、次のような質問をします。

  • "どの API 呼び出しを行う必要がありますか?"
  • "API 呼び出しのシーケンスは何ですか?"
  • "API 呼び出しで使用する必要があるテスト データは何ですか?"

回答に基づいて次の手順を行います。

  1. 主要なシナリオと依存関係を特定し、予想される使用量、可用性、パフォーマンス、スケーラビリティのターゲットを設定します。

  2. 一連の測定可能なしきい値を定義して、主要なシナリオの予想されるパフォーマンスを定量化します。 たとえば、アプリケーション コンポーネントに関しては、予想されるユーザー サインイン数、API の 1 秒あたりの要求数、バックグラウンド プロセスの 1 秒あたりの操作数のしきい値を考慮することができます。

  3. そのしきい値を使用して、アプリケーションのパフォーマンスのテスト、予想されるスケーリング操作の検証、関連するアクティビティのための現実的なトラフィックを生成するロード テストを定義します。 これらのしきい値を使用して、テストと運用の両方をカバーするアプリケーションの正常性モデルを開発します。

    チェックアウト プロセス フローの例では、各ステップの平均ページ読み込み時間のしきい値を 500 ミリ秒未満に設定し、最大 100 人の同時ユーザーをサポートできます。

すべてのしきい値が定義されたので、ロード テストを実装できます。 このモジュールでは、Azure Load Testing を使用します。

Azure portal を使用して Azure Load Testing を構成してデプロイすることはできますが、プログラムによるアプローチを強くお勧めします。 API を使用して、自動化された方法でテストをデプロイ、構成、実行します。 この方法は、次のユニットで説明します。

知識チェック

1.

すべてのユーザーおよびシステム フローは同じように重要ですか?

2.

コンポーネントが停止すると、常にサービスが低下しますか?

3.

ロード テストは、ユーザー フローの予想されるパフォーマンスを評価するのに役立ちますか?