Azure Functions のタイマー トリガーを使用して Azure Cosmos DB のスループットをスケーリングする
適用対象: NoSQL
Azure Cosmos DB アカウントのパフォーマンスは、要求ユニット/秒 (RU/秒) で表されるプロビジョニングされているスループットの量に基づいています。 プロビジョニングの粒度は 1 秒であり、1 時間あたりの最大 RU/秒に基づいて課金されます。 容量がプロビジョニングされるというモデルによって、予測可能で一貫性のあるスループットをサービスが提供でき、待機時間が短くなり、可用性が高くなります。 ほとんどの運用ワークロードがこれらの機能を備えています。 ただし、Azure Cosmos DB が業務時間中にのみ使用される開発およびテスト環境では、朝にスループットをスケールアップし、業務時間後の夕方にスケールダウンして戻すことができます。
スループットは、NoSQL 用 API アカウントに対して Azure Resource Manager テンプレート、Azure CLI、および PowerShell を使用して、または言語固有の Azure Cosmos DB SDK を使用して設定できます。 Resource Manager テンプレート、Azure CLI、または PowerShell を使用する利点は、これらがすべての Azure Cosmos DB モデル API をサポートしていることです。
スループット スケジューラのサンプル プロジェクト
スケジュールに従って Azure Cosmos DB をスケーリングするプロセスを簡素化するために、Azure Cosmos DB スループット スケジューラと呼ばれるサンプル プロジェクトを作成しました。 このプロジェクトは、"ScaleUpTrigger" と "ScaleDownTrigger" の 2 つのタイマー トリガーを持つ Azure Functions アプリです。 これらトリガーは、各トリガーの resources.json
ファイルで定義された各リソースに関するスループットを設定する PowerShell スクリプトを実行します。 ScaleUpTrigger は午前 8 時 (UTC) に実行されるように構成され、ScaleDownTrigger は午後 6 時 (UTC) に実行されるように構成されています。これらの時刻は、各トリガーの function.json
ファイル内で容易に更新できます。
このプロジェクトをローカルで複製し、スケールアップおよびスケールダウンする Azure Cosmos DB リソースと実行されるスケジュールを指定するように変更できます。 後で、それを Azure サブスクリプションにデプロイし、"Azure Cosmos DB オペレーター" ロールの Azure ロールベースのアクセス制御 (Azure RBAC) アクセス許可を持つマネージド サービス ID を使用してセキュリティで保護することにより、Azure Cosmos DB アカウントでスループットを設定できます。
次の手順
- 詳細については、Azure Cosmos DB スループット スケジューラからサンプルをダウンロードしてください。