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

マルチセッションOSデリバリーグループのユーザーインターフェイス:
タグ付きマシンのAutoscale(/ja-jp/citrix-virtual-apps-desktops/2411/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/2411/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)が含まれており、カタログC1から5台(M1~M5)、カタログC2から5台(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マシンでホストされるように指示されません。