タグ付きマシンの自動スケーリング (クラウドバースト)
注:
この機能は以前、Restrict Autoscaleという名称でした。
はじめに
Autoscaleは、デリバリーグループ内のマシンの一部のみを電源管理する柔軟性を提供します。これを実現するには、1台以上のマシンにタグを適用し、Autoscaleがタグ付きマシンのみを電源管理するように構成します。
この機能は、クラウドベースのリソースが追加の需要(つまり、バーストワークロード)に対応する前に、オンプレミスリソース(または予約済みのパブリッククラウドインスタンス)を使用してワークロードを処理したいクラウドバーストのユースケースで役立ちます。オンプレミスのマシン(または予約済みインスタンス)に最初にワークロードを処理させるには、タグ制限とゾーン優先度を組み合わせて使用する必要があります。
タグ制限は、Autoscaleによって電源管理されるマシンを指定します。ゾーン優先度は、ユーザー起動要求を処理するために優先ゾーン内のマシンを指定します。詳細については、「タグ」および「ゾーン優先度」を参照してください。
特定のタグ付きマシンを自動スケーリングするには、ManageコンソールまたはPowerShellを使用できます。
Manageコンソールを使用して特定のタグ付きマシンを自動スケーリングする
特定のタグ付きマシンを自動スケーリングするには、次の手順を実行します。
-
タグを作成し、そのタグをデリバリーグループ内の該当するマシンに適用します。詳細については、「タグとタグ制限の管理」を参照してください。
-
デリバリーグループを選択し、Manage Autoscaleウィザードを開きます。
-
タグ付きマシンの自動スケーリングページで、タグ付きマシンの自動スケーリングを有効にするを選択し、リストからタグを選択して、適用をクリックして変更を保存します。
シングルセッションOSの静的およびランダムデリバリーグループのユーザーインターフェイス:

マルチセッションOSデリバリーグループのユーザーインターフェース:
タグ付きマシンのAutoscale(/ja-jp/citrix-virtual-apps-desktops/2407/media/autoscale-restrict-ss-ms.png)
警告:
- 特定のタグが付いたマシンのAutoscaleにより、タグごとのマシンの数を反映するようにヒストグラムが自動的に更新される可能性があります。「スケジュールとピーク時間」ページで、必要に応じて、各時間帯にマシンを手動で割り当てることができます。
- タグ付きマシンで使用されているタグは削除できません。タグを削除するには、まずタグの制限を解除する必要があります。
タグの制限を適用した後、後でデリバリーグループから削除したい場合があります。そのためには、「Autoscaleの管理 > タグ付きマシンのAutoscale」ページに移動し、「タグ付きマシンのAutoscaleを有効にする」のチェックを外します。
警告:
- 「タグ付きマシンのAutoscaleを有効にする」のチェックを外さずに、該当するマシンからタグを削除すると、「Autoscaleの管理」ウィザードを開いたときに警告が表示されることがあります。マシンからタグを削除すると、Autoscaleで指定したタグが無効になるため、Autoscaleが管理するマシンがなくなる可能性があります。警告を解決するには、「タグ付きマシンのAutoscale」ページに移動し、無効なタグを削除して、「適用」をクリックして変更を保存します。
Autoscaleがリソースの電源をオンにするタイミングを制御する
タグなしマシンの使用状況に基づいて、Autoscaleがタグ付きマシンの電源をオンにし始めるタイミングを制御することもできます。これにより、タグ付きまたはパブリッククラウドのワークロードの消費をさらに最適化できます。
これを行うには、次の手順を完了します。
- 「タグ付きマシンのAutoscale」ページで、「Autoscaleがタグ付きマシンの電源をオンにし始めるタイミングを制御する」を選択します。
- ピーク時とオフピーク時の両方で到達したいタグなしマシンの使用率を入力し、「適用」をクリックします。サポートされている値:0~100。
Autoscaleがタグ付きマシンの電源をオンにし始めるタイミングを制御する(/ja-jp/citrix-virtual-apps-desktops/2407/media/autoscale-powers-on-tagged-machines.png)
ヒント:
この割合は、Autoscaleがタグ付きマシンの電源をオンにし始めるタイミングを制御します。割合がしきい値(デフォルト10%)を下回ると、Autoscaleはタグ付きマシンの電源をオンにし始めます。割合がしきい値を超えると、Autoscaleは電源オフモードに入ります。割合を入力する際は、次の2つのシナリオを考慮してください。
- シングルセッションOSデリバリーグループの場合:値は、アイドル状態のタグなしマシンの総数に対する割合として定義されます。例:タグなしのシングルセッションOSマシンが10台あるとします。セッションがないマシンが1台だけになると、Autoscaleはタグ付きマシンの電源をオンにし始めます。
- マルチセッションOSデリバリーグループの場合:値は、利用可能なタグなしマシンの総容量(負荷インデックスの観点から)に対する割合として定義されます。例:タグなしのマルチセッションOSマシンが10台あるとします。それらが90%ロードされると、Autoscaleはタグ付きマシンの電源をオンにし始めます。
PowerShellを使用して特定のタグ付きマシンを自動スケールする
PowerShell SDKを直接使用するには、次の手順を実行します。
-
タグを作成します。 New-Brokertag PowerShellコマンドを使用してタグを作成します。
- 例:
$managed = New-BrokerTag Managed。この場合、タグは「Managed」という名前です。New-Brokertag PowerShellコマンドの詳細については、https://developer-docs.citrix.com/projects/delivery-controller-sdk/en/latest/Broker/New-BrokerTag/を参照してください。
- 例:
-
マシンにタグを適用します。 Get-Brokermachine PowerShellコマンドを使用して、Autoscaleに電源管理させたいカタログ内のマシンにタグを適用します。
- 例:
Get-BrokerMachine -CatalogName "cloud" | Add-BrokerTag $managed.Name。この場合、カタログは「cloud」という名前です。 - Get-Brokermachine PowerShellコマンドの詳細については、https://developer-docs.citrix.com/projects/delivery-controller-sdk/en/latest/Broker/Get-BrokerMachine/を参照してください。
注:
タグを適用した後で、カタログに新しいマシンを追加する場合があります。タグは、それらの新しいマシンに自動的に適用されるわけではありません。
- 例:
-
Autoscaleに電源管理させたいデリバリーグループにタグ付きマシンを追加します。 Get-BrokerDesktopGroup PowerShellコマンドを使用して、マシンを含むデリバリーグループにタグ制限を追加します(つまり、「タグXを持つマシンへの起動を制限する」)。
- 例:
Get-BrokerDesktopGroup -Uid 1 | Set-BrokerDesktopGroup -RestrictAutoscaleTagUid $managed.Uid。この場合、デリバリーグループのUIDは1です。 - Get-BrokerDesktopGroup PowerShell コマンドに関する詳細については、https://developer-docs.citrix.com/projects/delivery-controller-sdk/en/latest/Broker/Get-BrokerDesktopGroup/ を参照してください。
- 例:
タグ制限を適用した後、後でデリバリーグループから削除したい場合があります。そのためには、Get-BrokerDesktopGroup PowerShellコマンドを使用します。
例: Get-BrokerDesktopGroup –Uid 1 | Set-BrokerDesktopGroup –RestrictAutoscaleTagUid $null。この場合、デリバリーグループのUIDは1です。
注:
タグ付けされていないマシンは、ユーザーが電源を切った後、自動的に再起動します。この動作により、ワークロードをより早く処理できるようになります。これは、
Set-BrokerDesktopGroupのAutomaticRestartForUntaggedMachinesプロパティを使用して、デスクトップグループごとに有効または無効にできます。詳細については、https://citrix.github.io/delivery-controller-sdk/Broker/Set-BrokerDesktopGroup/を参照してください。
シナリオ例
次のシナリオを想定します。
-
マシンカタログの構成。2つのマシンカタログ(C1とC2)があります。
- カタログC1には、オンプレミス展開にある5台のマシン(M1~M5)が含まれています。
- カタログC2には、クラウド展開にある5台のマシン(M6~M10)が含まれています。
-
タグ制限。「Cloud」という名前のタグが作成され、カタログC2内のマシンM6~M10に適用されます。
-
ゾーン構成。2つのゾーン(Z1とZ2)が作成されます。
- カタログC1を含むゾーンZ1は、オンプレミス展開に対応します。
- カタログC2を含むゾーンZ2は、クラウド展開に対応します。
-
デリバリーグループの構成
- デリバリーグループには、10台のマシン(M1~M10)が含まれており、そのうち5台はカタログC1(M1~M5)から、5台はカタログC2(M6~M10)からです。
- マシンM1からM5は手動で電源がオンにされ、スケジュール期間中ずっと電源がオンのままになります。
-
オートスケールの構成
- 容量バッファは10%に設定されています。
- Autoscaleは「Cloud」タグが付いたマシンのみを電源管理します。この場合、AutoscaleはクラウドマシンM6からM10を電源管理します。
-
公開アプリケーションまたはデスクトップの構成。公開デスクトップ(例)にはゾーン設定が構成されており、ユーザーの起動リクエストではゾーンZ2よりもゾーンZ1が優先されます。
- ゾーンZ1は、公開デスクトップの優先ゾーン(ホームゾーン)として構成されています。
シナリオは以下の順序で実行されます。
- ユーザーはログオンしません。
- ユーザーセッションが増加します。
- 利用可能なすべてのオンプレミス マシンが消費されるまで、ユーザーセッションはさらに増加します。
- さらにユーザーセッションが開始されます。
- セッション終了によりユーザーセッションが減少します。
- セッション負荷がオンプレミス マシンのみで処理されるまで、ユーザーセッションはさらに減少します。
上記シナリオにおけるAutoscaleの動作の詳細については、以下を参照してください。
- ユーザー負荷なし(初期状態)
- オンプレミス環境のマシンM1からM5はすべて電源が入っています。
- クラウド内のマシン1台(例: M6)の電源が入っています。このマシンは、構成された容量バッファのために電源が入っています。この場合、10(マシン数)x 10,000(負荷インデックス)x 10%(構成された容量バッファ)は10,000になります。したがって、マシン1台の電源が入っています。
- 電源が入っているすべてのマシン(M1からM6)の負荷インデックス値は、ベースライン負荷(負荷インデックスは0)です。
- ユーザーがログオンします
- セッションは、構成されたゾーン設定を通じてマシンM1からM5でホストされるように指示され、これらのオンプレミス環境のマシン間で負荷分散されます。
- 電源が入っているマシン(M1からM5)の負荷インデックス値が増加します。
- 電源が入っているマシンM6の負荷インデックス値は、ベースライン負荷です。
- ユーザーが負荷を増やし、すべてのオンプレミスリソースを消費します
- セッションは、構成されたゾーン設定を通じてマシンM1からM5でホストされるように指示され、これらのオンプレミス環境のマシン間で負荷分散されます。
- 電源が入っているすべてのマシン(M1からM5)の負荷インデックス値は10,000に達しました。
- 電源が入っているマシンM6の負荷インデックス値は、ベースライン負荷のままです。
- もう1人のユーザーがログオンします
- セッションはゾーン設定を超過し、クラウドマシンM6でホストされるように指示されます。
- 電源が入っているすべてのマシン(M1からM5)の負荷インデックス値は10,000に達しました。
- 電源が入っているマシンM6の負荷インデックス値が増加し、ベースライン負荷ではなくなります。負荷インデックスの観点から総予備容量が10,000を下回ると、構成された容量バッファのために、Autoscaleは需要を満たすため追加のマシン(M7)の電源を入れ始めます。マシンM7の電源を入れるには時間がかかる場合があることに注意してください。そのため、マシンM7が準備できるまでに遅延が発生する可能性があります。
- ユーザーがさらにログオンします
- セッションはマシンM6でホストされるように指示されます。
- 起動中のすべてのマシン(M1~M5)の負荷インデックス値が10,000に達しました。
- 起動中のマシンM6の負荷インデックス値はさらに増加しますが、総予備容量は負荷インデックスの観点から10,000を超えるレベルにあります。
- 起動中のマシンM7の負荷インデックス値はベースライン負荷のままです。
- さらに多くのユーザーがログオンします
- マシンM7の準備が整うと、セッションはマシンM6とM7でホストされるように指示され、これらのマシン間で負荷分散されます。
- 起動中のすべてのマシン(M1~M5)の負荷インデックス値が10,000に達しました。
- マシンM7の負荷インデックス値はもはやベースライン負荷ではありません。
- 起動中のマシン(M6とM7)の負荷インデックス値が増加します。
- 総予備容量は、負荷インデックスの観点から依然として10,000を超えるレベルにあります。
- セッション終了によりユーザーセッション負荷が減少します
- ユーザーがセッションからログオフするか、アイドルセッションがタイムアウトすると、マシンM1~M7で解放された容量は、他のユーザーが開始したセッションをホストするために再利用されます。
- 総予備容量が負荷インデックスの観点から10,000を超えるレベルに増加すると、Autoscaleはクラウドマシン(M6~M7)のいずれかをドレイン状態にします。その結果、新しい変更が発生しない限り、他のユーザーが開始したセッションはそのマシン(例:M7)に転送されなくなります。例えば、ユーザー負荷が再び増加したり、他のクラウドマシンの負荷が最も低くなったりした場合です。
- 1つ以上のクラウドマシンが不要になるまで、ユーザーセッション負荷はさらに減少します。
- M7マシン上のすべてのセッションが終了し、指定された電源オフ遅延がタイムアウトすると、AutoscaleはM7マシンの電源をオフにします。
- 電源がオンになっているすべてのマシン(M1~M5)の負荷インデックス値は、10,000を下回るレベルに低下する可能性があります。
- 電源がオンになっているマシン(M6)の負荷インデックス値は減少します。
- クラウドマシンが不要になるまで、ユーザーセッションはさらに減少します。
- M6マシンにユーザーセッションがない場合でも、予備容量として予約されているため、Autoscaleは電源をオフにしません。
- 構成された容量バッファのため、Autoscaleは残りのクラウドマシンM6の電源をオンのままにします。そのマシンは、着信するユーザーにデスクトップを提供するのを待機しています。
- オンプレミス環境のマシンに利用可能な容量がある限り、セッションはM6マシンでホストされるように指示されません。