スケーラビリティとパフォーマンス

重要

2023 年 9 月 20 日以降は、新しい Personalizer リソースを作成できなくなります。 Personalizer サービスは、2026 年 10 月 1 日に廃止されます。

高パフォーマンスでトラフィックの多い Web サイトやアプリケーションには、スケーラビリティとパフォーマンスのために Personalizer で考慮すべき 2 つの主な要素があります。

  • Rank API 呼び出しを行うときに低待機時間を維持する
  • トレーニングのスループットがイベント入力に追いついていることを確認する

パーソナル化からは高速に順位が返され、呼び出し時間のほとんどを REST API を介した通信が占めます。 Azure では、要求に迅速に対応するために、機能が自動スケーリングされます。

低待機時間シナリオ

一部のアプリケーションでは、順位を返すときに低待機時間を必要とします。 低待機時間は次のために必要です。

  • 優先度付けされたコンテンツが表示されるまでに、ユーザーが長時間待機しないようにする。
  • 極端なトラフィックが発生しているサーバーによって、十分ではないコンピューティング時間とネットワーク接続が妨害されないように防ぐ。

スケーラビリティとトレーニングのスループット

Rank および Reward API の後に Personalizer から非同期的に送信されるメッセージに基づいて再トレーニングされるモデルを更新することで、Personalizer は機能します。 これらのメッセージは、アプリケーション用の Azure EventHub を使用して送信されます。

ほとんどのアプリケーションは、Personalizer の参加およびトレーニングのスループットの上限に達する可能性はほぼありません。 この上限に達してもアプリケーションは遅くなりませんが、イベント ハブのキューがクリーンアップされるよりも早く内部的にいっぱいになる可能性があります。

スループット要件を推定する方法

  • コンテキストとアクションの JSON ドキュメントの長さを足し合わせて、優先度付け イベントあたりの平均バイト数を推定します。
  • この推定平均バイト数で 20 MB/秒を割ります。

たとえば、平均的なペイロードに 500 個の機能があり、それぞれが推定 20 文字の場合、各イベントは約 10 KB です。 このような推定の場合、20,000,000 / 10,000 = 2,000 イベント/秒、つまり約 1 億 7,300 万イベント/日です。

このような制限に達している場合は、Microsoft のサポート チームに連絡してアーキテクチャのアドバイスを受けてください。

次のステップ

Personalizer の作成と構成