アプリケーション
注:
Citrix Virtual Apps and Desktops™の展開は、Web Studio(ウェブを基盤とした)とCitrix Studio(Windowsを基盤とした)の2つの管理コンソールを使用して管理できます。この記事ではWeb Studioのみを扱います。Citrix Studioに関する情報は、Citrix Virtual Apps and Desktops 7 2212以前の該当記事を参照してください。
はじめに
展開でデリバリーグループのみを使用している場合(アプリケーショングループを使用していない場合)、アプリケーションをデリバリーグループに追加します。アプリケーショングループも使用している場合は、通常、代わりにアプリケーションをアプリケーショングループに追加します。このガイダンスにより、管理が容易になります。アプリケーションは常に、少なくとも1つのデリバリーグループまたはアプリケーショングループに属している必要があります。
アプリケーションの追加ウィザードでは、1つ以上のデリバリーグループ、または1つ以上のアプリケーショングループを選択できますが、両方を選択することはできません。後でアプリケーションのグループ関連付けを変更できますが(たとえば、アプリケーションをアプリケーショングループからデリバリーグループに移動するなど)、ベストプラクティスとしては、そのような複雑さを追加することは推奨されません。アプリケーションは1種類のグループに保持してください。
アプリケーションを複数のグループに関連付ける場合、それらのすべてのグループでアプリケーションを表示するのに十分な権限がないと、表示の問題が発生する可能性があります。そのような場合は、より高い権限を持つ管理者に相談するか、アプリケーションが関連付けられているすべてのグループを含むようにスコープを拡張してください。
同じ名前の2つのアプリケーション(おそらく異なるグループからのもの)を同じユーザーに公開する場合、Web StudioでApplication name (for user)プロパティを変更します。そうしないと、ユーザーはCitrix Workspace™アプリで重複する名前を目にすることになります。
アプリケーションのプロパティ(設定)は、追加時または後で変更できます。アプリケーションが配置されるアプリケーションフォルダーも、アプリケーションの追加時または後で変更できます。
詳細については、以下を参照してください。
アプリケーションの追加
アプリケーションは、デリバリーグループまたはアプリケーショングループを作成するときに追加できます。これらの手順は、デリバリーグループの作成およびアプリケーショングループの作成で詳しく説明されています。次の手順では、グループ作成後にアプリケーションを追加する方法について説明します。
知っておくと便利な情報:
- Remote PC Accessデリバリーグループにアプリケーションを追加することはできません。
- アプリケーションの追加ウィザードを使用して、デリバリーグループまたはアプリケーショングループからアプリケーションを削除することはできません。これは別の操作です。
1つ以上のアプリケーションを追加するには:
- 左ペインで[アプリケーション]を選択し、アクションバーで[アプリケーションの追加]を選択します。
- アプリケーションの追加ウィザードが[はじめに]ページとともに起動します。このページは、次回以降のウィザード起動時に表示しないように設定できます。
- ウィザードは、[グループ]、[アプリケーション]、[概要]の各ページを案内します。各ページの作業が完了したら、[次へ]をクリックして[概要]ページに進みます。
単一のデリバリーグループまたはアプリケーショングループにアプリケーションを追加する場合の、手順1の代替案:
- 1つのデリバリーグループにのみアプリケーションを追加する場合: 手順1で、Web Studioの左ペインで[デリバリーグループ]を選択し、中央ペインでデリバリーグループを選択してから、アクションバーで[アプリケーションの追加]を選択します。ウィザードには[グループ]ページが表示されません。
- 1つのアプリケーショングループにのみアプリケーションを追加する場合: 手順1で、Web Studioの左ペインで[アプリケーション]を選択し、中央ペインでアプリケーショングループを選択してから、アクションバーのアプリケーショングループ名の項目にある[アプリケーションの追加]を選択します。ウィザードには[グループ]ページが表示されません。
グループページ
このページには、サイト内のすべてのデリバリーグループが一覧表示されます。アプリケーショングループも作成している場合は、アプリケーショングループとデリバリーグループが一覧表示されます。どちらかのグループを選択できますが、両方のグループを選択することはできません。つまり、アプリケーションをアプリケーショングループとデリバリーグループに同時に追加することはできません。通常、アプリケーショングループを使用している場合は、デリバリーグループではなくアプリケーショングループにアプリケーションを追加します。
アプリケーションを追加するときは、少なくとも1つのデリバリーグループ(または、利用可能な場合はアプリケーショングループ)の横にあるチェックボックスをオンにします。すべてのアプリケーションは、常に少なくとも1つのグループに関連付けられている必要があります。
アプリケーションページ
[追加]をクリックして、アプリケーションソースを表示します。
-
スタートメニューから: 選択したデリバリーグループ内のマシンで検出されたアプリケーション。このソースを選択すると、検出されたアプリケーションのリストを含む新しいページが起動します。追加するアプリケーションのチェックボックスを選択し、OKをクリックします。
このソースは、(1)関連付けられたデリバリーグループがないアプリケーショングループを選択した場合、(2)マシンを含まない関連付けられたデリバリーグループを持つアプリケーショングループを選択した場合、または(3)マシンを含まないデリバリーグループを選択した場合には選択できません。
-
手動で: デリバリーグループ内のVDA、またはネットワーク上の他の場所にあるアプリケーション。このソースを選択すると、以下の方法で追加するアプリケーションを指定する新しいページが開きます。
- 実行可能ファイルへのパス、作業ディレクトリ、オプションのコマンドライン引数、および管理者とユーザーの表示名を入力します。
- デリバリーグループ内のVDAからアプリケーションを選択します。これを行うには、参照をクリックし、VDAにアクセスするための資格情報を入力し、VDAへの接続を待ってから、VDAからアプリケーションを選択します。選択したアプリケーションのプロパティが、ページのフィールドに自動的に入力されます。
-
既存: 以前にサイトに追加されたアプリケーション。このソースを選択すると、検出されたアプリケーションのリストを含む新しいページが起動します。追加するアプリケーションのチェックボックスを選択し、OKをクリックします。
サイトにアプリケーションがない場合、このソースは選択できません。
-
アプリケーションパッケージ: App-V、MSIX、MSIX app attach、またはFlexAppアプリケーションパッケージ内のアプリケーション。このソースを選択すると、パッケージからアプリケーションを追加ページが起動します。アプリケーションパッケージソースを選択し、表示された結果から追加したいアプリケーションを選択し、OKを選択します。詳細については、アプリパッケージの展開と配信を参照してください。
-
アプリケーショングループ: アプリケーショングループ。このソースを選択すると、アプリケーショングループのリストを含む新しいページが起動します。(表示には各グループ内のアプリケーションもリストされますが、個々のアプリケーションではなくグループのみを選択できます。) 選択したグループ内の現在および将来のすべてのアプリケーションが追加されます。追加するアプリケーショングループのチェックボックスを選択し、OKをクリックします。
このソースは、(1)アプリケーショングループがない場合、または(2)選択したデリバリーグループがアプリケーショングループをサポートしていない場合(たとえば、静的に割り当てられたマシンを持つデリバリーグループなど)には選択できません。
表に示されているように、追加リスト内の一部のソースは、そのタイプの有効なソースがない場合、選択できません。互換性のないソース(たとえば、アプリケーショングループにアプリケーショングループを追加できないなど)はリストに含まれません。選択したグループに既に追加されているアプリケーションは選択できません。
このページまたは後で、アプリケーションのプロパティ(設定)を変更できます。
デフォルトでは、追加されたアプリケーションはApplicationsという名前のアプリケーションフォルダーに配置されます。このページまたは後でアプリケーションを変更できます。アプリケーションを追加しようとして、同じ名前のアプリケーションが同じフォルダーに存在する場合、追加しようとしているアプリケーションの名前を変更するよう求められます。提示された新しい名前を受け入れるか、拒否してアプリケーションの名前を変更するか、別のフォルダーを選択できます。たとえば、Applicationsフォルダーにappが既に存在し、そのフォルダーにappという名前の別のアプリケーションを追加しようとすると、新しい名前app_1が提示されます。
概要ページ
追加するアプリケーションが10個以下の場合は、その名前が追加するアプリケーションにリストされます。10個を超えるアプリケーションを追加する場合は、合計数が指定されます。
概要情報を確認し、その後、Finishをクリックします。
アプリケーションのグループ関連付けを変更する
アプリケーションを追加した後、そのアプリケーションが関連付けられているデリバリーグループとアプリケーショングループを変更できます。
アプリケーションを別のグループにドラッグできます。これは、アクションバーのコマンドを使用する代わりの方法です。
アプリケーションが複数のデリバリーグループに関連付けられている場合(アプリケーショングループを使用するか直接関連付けるかに関わらず)、グループの優先度を使用して、複数のグループが評価される順序を指定できます。グループは、アクセスポリシー、ユーザーリスト、スマートアクセスタグなどの要因に基づいて考慮対象から除外でき、グループから選択される特定のマシンは、ゾーンの優先度、起動準備状況、タグの制限などの要因によって影響を受ける可能性があります。デフォルトでは、すべてのグループの優先度は0(最高)です。デリバリーグループの優先度が同じ場合、アプリケーションの起動には最も負荷の低いデリバリーグループが選択されます。この場合、垂直ロードバランシングは考慮されません。
アプリケーションは、アプリケーションを配信できる共有(プライベートではない)マシンを含むデリバリーグループに関連付けることができます。また、(1) デリバリーグループに共有マシンが含まれており、XenDesktop 7.x バージョン 7.9 より前のバージョンで作成された場合、および (2) Edit delivery group 権限がある場合、デスクトップのみを配信する共有マシンを含むデリバリーグループを選択することもできます。プロパティダイアログがコミットされると、デリバリーグループの種類は自動的に desktops and applications に変換されます。
- Web Studioにサインインし、左ペインでApplicationsを選択し、その後、アプリケーションを選択します。
- アクションバーでPropertiesを選択します。
-
Groupsページを選択します。
- グループを追加するには、Addをクリックし、Application GroupsまたはDelivery Groupsを選択します。(アプリケーショングループを作成していない場合、唯一のエントリはDelivery Groupsです。)その後、1つ以上の利用可能なグループを選択します。アプリケーションと互換性のないグループ、またはすでにアプリケーションに関連付けられているグループは選択できません。
- グループを削除するには、1つ以上のグループを選択し、Removeをクリックします。グループ関連付けを削除した結果、アプリケーションがどのグループにも関連付けられなくなる場合、アプリケーションが削除されることを警告されます。
- グループの優先度を変更するには、グループを選択し、Edit Priorityをクリックします。優先度値を選択し、OKをクリックします。
- 完了したら、変更を適用してウィンドウを開いたままにするにはApplyをクリックするか、変更を適用してウィンドウを閉じるにはOKをクリックします。
アプリケーションを複製、有効化または無効化、名前変更、または削除する
次のアクションが利用可能です。
- 複製: 異なるパラメーターまたはプロパティを持つ別のバージョンを作成するために、アプリケーションを複製したい場合があります。アプリケーションを複製すると、一意のサフィックスで自動的に名前が変更され、元のアプリケーションの隣に配置されます。また、アプリケーションを複製してから、別のグループに追加したい場合もあります。(複製後、アプリケーションを移動する最も簡単な方法はドラッグすることです。)
- 有効化または無効化: アプリケーションの有効化と無効化は、デリバリーグループまたはアプリケーショングループの有効化と無効化とは異なるアクションです。
- 名前の変更: 一度に1つのアプリケーションのみ名前を変更できます。アプリケーションの名前を変更しようとして、同じ名前のアプリケーションが同じフォルダーまたはグループに存在する場合、別の名前を指定するように求められます。
- 削除: アプリケーションを削除すると、関連付けられていたデリバリーグループおよびアプリケーショングループから削除されますが、元々アプリケーションを追加するために使用されたソースからは削除されません。アプリケーションの削除は、デリバリーグループまたはアプリケーショングループから削除するのとは異なるアクションです。
アプリケーションを複製、有効化、無効化、名前変更、または削除するには:
- 左ペインでアプリケーションを選択します。
- 中央ペインで1つ以上のアプリケーションを選択し、アクションバーで適切なタスクを選択します。
- プロンプトが表示されたら、アクションを確認します。
デリバリーグループからアプリケーションを削除する
アプリケーションは、少なくとも1つのデリバリーグループまたはアプリケーショングループに関連付けられている(属している)必要があります。アプリケーションをデリバリーグループから削除しようとして、そのアプリケーションとデリバリーグループまたはアプリケーショングループとの関連付けがすべて削除される場合、続行するとアプリケーションが削除されることが通知されます。その場合、そのアプリケーションを配信したい場合は、有効なソースから再度追加する必要があります。
- 左ペインでデリバリーグループを選択します。
- デリバリーグループを選択します。中央下部のペインで、アプリケーションタブで、削除するアプリケーションを選択します。
- アクションバーからアプリケーションの削除を選択します。
- 削除を確認します。
アプリケーショングループからアプリケーションを削除する
アプリケーションは、少なくとも1つのデリバリーグループまたはアプリケーショングループに属している必要があります。アプリケーションをアプリケーショングループから削除しようとして、その結果、そのアプリケーションがどのグループにも属さなくなる場合、続行するとアプリケーションが削除されるという通知が表示されます。その場合、そのアプリケーションを配信したい場合は、有効なソースから再度追加する必要があります。
- 左ペインでアプリケーションを選択します。
- 中央ペインでアプリケーショングループを選択し、1つ以上のアプリケーションを選択します。
- アクションバーでアプリケーショングループから削除を選択します。
- 削除を確認します。
アプリケーションプロパティの変更
一度に1つのアプリケーションのプロパティのみを変更できます。
アプリケーションのプロパティを変更するには:
- 左ペインでアプリケーションを選択します。
- アプリケーションを選択し、アクションバーでアプリケーションプロパティの編集を選択します。
- 変更したいプロパティを含むページを選択します。
- 完了したら、適用をクリックして行った変更を適用し、ウィンドウを開いたままにするか、OKをクリックして変更を適用し、ウィンドウを閉じます。
以下のリストでは、ページが括弧内に示されています。
| プロパティ | ページ |
|---|---|
| Citrix Workspaceアプリにアプリケーションが表示されるカテゴリ/フォルダー | 配信 |
| コマンドライン引数。公開アプリケーションにパラメーターを渡すを参照 | 場所 |
| アプリケーションが利用可能なデリバリーグループおよびアプリケーショングループ | グループ |
| 説明文 | 識別情報 |
| ファイル名拡張子とファイルタイプの関連付け: アプリケーションが自動的に開く拡張子 | ファイルタイプの関連付け |
| アイコン | 配信 |
| StoreFront™ に関連するキーワード | 識別情報 |
| 制限。アプリケーションの制限を構成するを参照 | 配信 |
| 名前: ユーザーおよび管理者に表示される名前 | 識別情報 |
| 実行可能ファイルへのパス。「公開アプリケーションにパラメーターを渡す」を参照してください。 | 場所 |
| ユーザーのデスクトップ上のショートカット: 有効または無効 | 配信 |
| 可視性: Citrix Workspaceアプリでアプリケーションを表示できるユーザーを制限します。非表示のアプリケーションでも起動できます。アプリケーションを使用不可にして非表示にするには、別のグループに追加します。 | 可視性の制限 |
| 作業ディレクトリ | 場所 |
アプリケーションの変更は、現在のアプリケーションユーザーがセッションからログオフするまで有効にならない場合があります。
アプリケーション制限の構成
アプリケーションの使用状況を管理するために、アプリケーション制限を構成します。たとえば、アプリケーション制限を使用して、アプリケーションに同時にアクセスするユーザーの数を管理できます。同様に、アプリケーション制限を使用して、リソースを大量に消費するアプリケーションの同時インスタンス数を管理できます。この制限は、サーバーのパフォーマンスを維持し、サービスの劣化を防ぐのに役立ちます。
この機能は、Controllerによって仲介されるアプリケーション起動の数(Citrix WorkspaceアプリやStoreFrontなどから)を制限するものであり、他の方法で起動できる実行中のアプリケーションの数を制限するものではありません。これは、アプリケーション制限が同時使用の管理において管理者を支援するものの、すべてのシナリオで強制力を持つわけではないことを意味します。たとえば、Controllerが停止モードの場合、アプリケーション制限は適用できません。
デフォルトでは、同時に実行できるアプリケーションインスタンスの数に制限はありません。アプリケーションの制限設定はいくつかあります。それらのいずれか、またはすべてを構成できます。
- デリバリーグループ内のすべてのユーザーによるアプリケーションの同時インスタンスの最大数。
- デリバリーグループ内のユーザーごとのアプリケーションインスタンスを1つ。
- マシンごとのアプリケーションの同時インスタンスの最大数(PowerShellのみ)。
制限が構成されている場合、ユーザーが構成された制限を超えるアプリケーションインスタンスを起動しようとすると、エラーメッセージが生成されます。複数の制限が構成されている場合、最初の制限に達したときにエラーが報告されます。
アプリケーションの制限を使用する例:
-
同時インスタンス数の上限: デリバリーグループで、アプリケーション
Alphaの同時インスタンスの最大数を15に構成します。その後、そのデリバリーグループのユーザーは、そのアプリケーションの15個のインスタンスを同時に実行しています。そのデリバリーグループのいずれかのユーザーがAlphaを起動しようとすると、エラーメッセージが生成されます。構成された同時アプリケーションインスタンスの制限(15)を超えるため、Alphaは起動されません。 -
ユーザーごとのインスタンス数1つのアプリケーション制限: 別のデリバリーグループで、アプリケーション
Betaのユーザーごとのインスタンス数1つのオプションを有効にします。ユーザーのTonyはアプリケーションBetaを正常に起動します。その日の後半、そのアプリケーションがTonyのセッションでまだ実行されている間に、彼はBetaの別のインスタンスを起動しようとします。エラーメッセージが生成され、ユーザーごとのインスタンス数1つの制限を超えるため、Betaは起動されません。 -
同時インスタンス数の上限とユーザーごとのインスタンス数1つの制限: 別のデリバリーグループで、同時インスタンスの最大数を10に構成し、アプリケーション
Deltaのユーザーごとのインスタンス数1つのオプションを有効にします。その後、そのデリバリーグループの10人のユーザーがそれぞれDeltaのインスタンスを実行している場合、そのデリバリーグループの他のユーザーがDeltaを起動しようとすると、エラーメッセージが表示されます。Deltaは起動されません。現在の10人のDeltaユーザーのいずれかがそのアプリケーションの2番目のインスタンスを起動しようとすると、エラーメッセージが表示され、2番目のインスタンスは起動されません。 -
マシンごとの同時インスタンス数の上限とタグ制限の使用: アプリケーション
Charlieには、特定のサーバーで同時に実行できるインスタンスの数を規定するライセンスおよびパフォーマンス要件があります。これらの要件は、サイト内のすべてのサーバーで同時に実行できるインスタンスの数も規定します。アプリケーションのインスタンス数/マシン制限は、サイト内のすべてのサーバー(特定のデリバリーグループ内のマシンだけでなく)に影響します。サイトに3台のサーバーがあるとします。アプリケーション
Charlieの場合、マシンごとのアプリインスタンス制限を2に構成します。したがって、サイト全体でアプリケーションCharlieのインスタンスは6つまでしか起動できません。(これは、3台のサーバーそれぞれでCharlieのインスタンスが2つという制限です。)アプリケーションの使用をデリバリーグループ内の特定のコンピューターのみに制限するには(サイト全体のすべてのコンピューターでのインスタンスの制限に加えて):
- それらのマシンにタグ付け機能を使用します。
- そのアプリケーションのマシンごとの最大インスタンス数を構成します。
Controllerの仲介以外の方法でアプリケーションが起動され(たとえば、Controllerが停止モードの場合など)、構成された制限を超過した場合、ユーザーは制限を超過しないように十分なインスタンスを閉じるまで、それ以上のインスタンスを起動できません。制限を超過したインスタンスは強制的にシャットダウンされません。ユーザーが閉じるまで、それらのインスタンスは継続して実行されます。
セッションローミングを無効にする場合は、ユーザーごとのアプリケーションインスタンス数制限を無効にします。ユーザーごとのアプリケーションインスタンス数制限を有効にする場合は、新しいデバイスで新しいセッションを許可する2つの値のいずれも構成しないでください。ローミングの詳細については、「セッション」を参照してください。
デリバリーグループあたりの最大インスタンス数制限と、ユーザーあたりのインスタンス数制限を構成するには:
- 左側のペインでアプリケーションを選択し、アプリケーションを選択します。
- アクションバーでアプリケーションプロパティの編集を選択します。
-
配信ページで、次のいずれかのオプションを選択します。
- アプリケーションの無制限の使用を許可する。同時に実行できるインスタンスの数に制限はありません。これがデフォルトです。
-
アプリケーションの制限を設定する。制限の種類は2つあります。いずれかまたは両方を指定します。
- マシンごとに同時に実行できるインスタンスの最大数を指定します
- ユーザーごとにアプリケーションのインスタンスを1つに制限する
- OKをクリックして変更を適用し、ダイアログボックスを閉じるか、適用をクリックして変更を適用し、ダイアログボックスを開いたままにします。
マシンあたりの最大インスタンス数制限を構成するには(PowerShellのみ):
- PowerShellで(Citrix Cloud™展開の場合はRemote PowerShell SDKを、オンプレミス展開の場合はPowerShell SDKを使用して)、適切な
BrokerApplicationコマンドレットをMaxPerMachineInstancesパラメーターとともに実行します。 -
ガイダンスについては、
Get-Helpコマンドレットを使用してください。例:Get-Help Set-BrokerApplication –Parameter MaxPerMachineInstances
公開アプリケーションにパラメーターを渡す
アプリケーションのプロパティの場所ページを使用して、コマンドラインを入力し、公開アプリケーションにパラメーターを渡します。
公開アプリケーションをファイルの種類に関連付けると、"%*" (二重引用符で囲まれたパーセント記号とアスタリスク記号) がアプリケーションのコマンドラインの末尾に追加されます。これらの記号は、ユーザーデバイスに渡されるパラメーターのプレースホルダーとして機能します。
公開アプリケーションが期待どおりに起動しない場合は、そのコマンドラインに正しい記号が含まれていることを確認してください。デフォルトでは、"%*" 記号が追加されると、ユーザーデバイスから提供されるパラメーターが検証されます。ユーザーデバイスから提供されるカスタマイズされたパラメーターを使用する公開アプリケーションの場合、コマンドライン検証をバイパスするために、"%**" 記号がコマンドラインに追加されます。アプリケーションのコマンドラインにこれらの記号が表示されない場合は、手動で追加してください。
実行可能ファイルへのパスにスペースを含むディレクトリ名が含まれている場合 ("C:\Program Files" など)、そのスペースがコマンドラインに属することを示すために、アプリケーションのコマンドラインを二重引用符で囲みます。これを行うには、パスを二重引用符で囲み、%* 記号を別の二重引用符で囲みます。パスの閉じ引用符と%* 記号の開き引用符の間にスペースを含めるようにしてください。
たとえば、公開アプリケーションであるWindows Media Playerのコマンドラインは次のとおりです。
"C:\Program Files\Windows Media Player\mplayer1.exe" "%*"
注:
公開アプリケーションを起動するためのコマンドラインの最大文字数 (引数を含む) は203文字です。
公開アプリケーションでのセッションサインアウトの問題のトラブルシューティング
アプリケーションを公開する場合、公開アプリケーションのメインの実行可能ファイルのみが指定されます。ただし、一部のアプリケーションは、バックグラウンドで実行され、メインの公開アプリケーションが閉じられても対応するメインの実行可能ファイルによって閉じられない追加の (子) プロセスを生成する場合があります。追加のプロセスは、実行されるスクリプトや、Run や RunOnceKey のような特定のレジストリキーから作成されることもあります。これらのアプリケーションは、正常なサインアウトを妨げ、セッションが残存したりハングしたりする原因となり、セッションが閉じられず、ユーザーがサインアウトされない可能性があります。
この場合、Citrix Directorを使用してこれらのセッションをリセットまたは終了する必要があります。
セッションが適切にサインアウトされない問題を特定し、トラブルシューティングするために、Citrixは3つのレジストリエントリを提供しています。これらの問題によりセッションが適切にログオフされないことの特定とトラブルシューティングは、次の3段階のプロセスです。
-
どのセッションに公開アプリケーションがあり、正常なサインアウトを妨げているかを特定する
ステップ2:公開アプリケーションが追加の(子)プロセスを生成するかどうかを特定する
公開アプリケーションが正常なサインアウトを妨げていると特定されたら、次のステップは、このアプリケーションが実行時に追加のプロセスを生成するかどうかを判断することです。
公開アプリケーションが閉じられたときに、プロセスが正常なサインアウトをブロックしているかどうかを判断するには、HKCU\Software\CitrixVolatile\Seamless\Sessions\[ID]\LogoffCheckerBlockingProcess を参照してください。
以下の例では、キー LogoffCheckerBlockingProcess に次のエントリが含まれています。
PhoneExperienceHost.exe
SkypeApp.exe
SkypeBackgroundHost.exe
<!--NeedCopy-->
これらのプロセスが正常なサインアウトを妨げていました。
注:
確認したいセッションの正しいセッションIDで [ID] を置き換えてください。
ステップ3:これらのプロセスを指定されたレジストリエントリに追加して、サインアウトを妨げないようにする
これらのプロセスを以下のレジストリキーに追加することで、今後のセッションでサインアウトが妨げられるのを防ぐことができます。
Add the process file name to the following registry key:
Caution! Refer to the Disclaimer at the end of this article before using the Registry Editor.
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Citrix\wfshell\TWI
Value Name:LogoffCheckSysModules
Type:REG_SZ
String:MyAppName.exe
<!--NeedCopy-->
LogoffCheckSysModules の詳細については、「公開アプリケーションからの正常なログオフによりセッションがアクティブ状態になる」を参照してください。
ステップバイステップのトラブルシューティングガイド
-
テスト対象のVDAでリモートレジストリサービスを開始します。
-
コントロールパネルで、管理ツール > サービス を選択します。
-
Remote Registry Service を右クリックし、プロパティ を選択します。
-
スタートアップの種類 で、ドロップダウンメニューから 自動 を選択します。

-
-
テスト対象のVDAでWindowsファイアウォールをオフにするか、ポート455を有効にする受信ファイアウォール規則を作成します。
-
コントロールパネルで、Windows Defender ファイアウォール > 詳細設定を選択します。
-
受信の規則を右クリックし、新しい規則を選択します。
-
新しい受信の規則ウィザードで、ポートを選択します。
-
プロトコルおよびポートページで、TCP および特定のローカルポートを選択します。ローカルポートとして
445を入力します。 -
操作ページで、接続を許可するを選択します。
-
新しい受信規則を適用するファイアウォールプロファイルを選択します。
-
ファイアウォール規則に名前を付け、完了を選択して新しい受信の規則ウィザードを終了します。

-
-
同じドメイン上の別のVM(DC、DDC、または別のVDAでも可)から、
Regeditを実行し、リモートレジストリに接続します。
-
テスト対象のVDAのIPアドレスを入力し、OKをクリックします。
regeditツリーには、テスト対象のVDAのブランチが表示される必要があります。
-
コマンドプロンプト公開アプリケーションを開きます。

コマンドプロンプトアプリがCitrix Workspaceに表示されます。

-
クライアントで接続センターを開きます。これは、開いているシームレスアプリを閉じた後、セッションがサインアウトされたときに監視するために使用されます。次の画像で、リモートVDIでコマンドプロンプトプロセス
c:\Windows\system32\cmd.exeがアクティブになっていることがわかります。
-
regeditが実行されているVDAから、次のリモートIPの場所に移動します。
HKEY_USERS\S-1-X-XX-XXXXXXXX-XXXXXXXXXXX-XXXXXXXXXX-XXXX\SOFTWARE\CitrixVolatile\Seamless\Sessions\X\注:
このパスは、新しいセッションを開くたびに変更されます。
-
ここで読み取るべきキーは2つあります(ここでは変更しないでください):LogoffCheckBlockingProcessとLogoffCheckerBlockingVisibleProcess。これらのキーは、サインアウトをブロックしているプログラムを表示します。最初のキーは、
C:\Windows\System32\cmd.exeを表示しているはずです。なぜなら、それが開いていてまだ閉じられていないからです。注:
LogoffCheckBlockingProcessとLogoffCheckerBlockingVisibleProcessは手動で編集してはなりません。これらのレジストリ値を手動で編集すると、セッションが不安定になる可能性があります。

-
右上隅のXをクリックして、Seamless CMDを終了します。
-
接続センターを確認して、セッションが閉じているか確認します。閉じるまでに最大30秒かかる場合があります。閉じている場合、正常なサインアウトを妨げたアプリケーションやプロセスはありませんでした。

-
セッションが閉じなかった場合、F5キーでregeditの出力を更新します。
-
LogoffCheckBlockingProcessとLogoffCheckerBlockingVisibleProcessの内容を再度確認します。CMDは存在しないはずですが、別のプロセスがリストされているはずです。現在セッションのサインアウトをブロックしているプロセスがここに表示されているはずです。
このケースでは、公開されたコマンドプロンプトからNotepad.exeが開かれており、コマンドプロンプトが閉じられる前にこのリモートのメモ帳プロセスが正常なサインアウトを妨げています。

-
この実行可能ファイルのパスと、それが表示されたキーをメモし、リモートツリーの下にある以下のレジストリキーに入力します。
- もし、それが LogoffCheckBlockingProcess のリストに表示されている場合:
HKLM\SYSTEM\CurrentControlSet\Control\Citrix\wfshell\TWILogoffCheckSysModulesInternal -
LogoffCheckerBlockingVisibleProcessという項目にその名前がリストアップされている場合:
HKLM\SYSTEM\CurrentControlSet\Control\Citrix\wfshell\TWILogoffCheckVisibleSysModules
注:
キーにすでに1つ以上のエントリがある場合は、末尾にコンマを追加し、そのコンマの後に新しいエントリを配置します。

- もし、それが LogoffCheckBlockingProcess のリストに表示されている場合:
-
クライアントの接続センターからセッションをサインアウトし、リモートアプリケーションを再度開きます。
-
リモートアプリケーションを閉じてから30秒以内にセッションが自動的にサインアウトされるまで、手順9~16を繰り返します。
注:
トラブルシューティング後、必要に応じて、リモートレジストリへのアクセスを許可するために一時的なファイアウォールの変更を元に戻します。
公開されたアプリケーションを開くときにWindowsの免責事項メッセージをフルサイズで表示するようにLogonUIを変更する方法
認証パススルーが発生しないシナリオでは、LogonUI ウィンドウのスケーリングが改善されました。LogonUI ウィンドウは、モニターの解像度と使用されているDPI設定に基づいてスケーリングされ、LogonUI ウィンドウ全体がクリッピングなしで表示されるようにします。
ウィンドウのサイズは、レジストリで手動でピクセル単位で設定することもできます。
-
ファイル名を指定して実行コマンドで
regeditを使用して、レジストリエディターを開きます。 -
HKEY_LOCAL_MACHINE\Software\Citrix\CtxHook\AppInit_DLLS\Seamless Hook\に移動します。 -
以下の2つの新しいDWORDキーを、LogonUIWidth および LogonUIHeight として作成します。
-
キーの値を、LogonUI ウィンドウに必要な幅と高さ(ピクセル単位)に設定します。
LogonUI ウィンドウのサイズを手動で設定すると、自動スケーリングは無効になります。
注:
これらのレジストリパスは2407以降変更されました。古いレジストリ値は無視され、非推奨です。
デフォルトでは、LogonUI ウィンドウには閉じるボタン付きのタイトルバーが含まれており、必要に応じてエンドユーザーがセッションから切断できるようになっています。
タイルバーを無効にする
以下のレジストリキーを使用して、LogonUI ウィンドウのタイルバーを無効にできます。
-
ファイル名を指定して実行コマンドで
regeditを使用して、レジストリエディターを開きます。 -
HKEY_LOCAL_MACHINE\Software\Citrix\CtxHook\AppInit_DLLS\Seamless Hook\に移動します。 -
新しいDWORDキーLogonUICaptionを作成し、キーの値を
0に設定します。タイルバー付きのLogonUIウィンドウのスクリーンショット(/ja-jp/citrix-virtual-apps-desktops/2411/media/logonui-window-with-tilebar.png)
アプリケーションフォルダーの管理
デフォルトでは、デリバリーグループに追加する新しいアプリケーションは、Applicationsという名前のフォルダーに配置されます。デリバリーグループの作成時、アプリケーションの追加時、または後で別のフォルダーを指定できます。
知っておくと良いこと:
- Applicationsフォルダーの名前を変更したり削除したりすることはできませんが、その中に含まれるすべてのアプリケーションを、作成した他のフォルダーに移動することはできます。
- フォルダー名には1~64文字を含めることができます。スペースも使用できます。
- フォルダーは最大5レベルまでネストできます。
- フォルダーにアプリケーションを含める必要はありません。空のフォルダーも許可されます。
- フォルダーは、移動したり、作成時に別の場所を指定したりしない限り、Web Studioでアルファベット順に表示されます。
- 親フォルダーが異なる限り、同じ名前のフォルダーを複数持つことができます。同様に、異なるフォルダーにある限り、同じ名前のアプリケーションを複数持つことができます。
- フォルダー内のアプリケーションを表示するには
View Applications権限が必要です。また、アプリケーションを含むフォルダーを削除、名前変更、または削除するには、そのフォルダー内のすべてのアプリケーションに対してEdit Application Properties権限が必要です。 - 以下の手順のほとんどは、Web Studioのアクションバーを使用してアクションを要求します。または、右クリックメニューを使用するか、アイテムをドラッグすることもできます。たとえば、意図しない場所にフォルダーを作成または移動した場合、ドラッグアンドドロップで正しい場所に移動できます。
-
Web Studioのすべてのノード(マシンカタログ、デリバリーグループ、アプリケーション、アプリケーショングループなど)は、バックエンドで同じフォルダーツリーを共有します。フォルダーの名前変更や移動時の名前の競合を避けるため、異なるノード間で最上位フォルダーには一意の名前を使用してください。
New-BrokerAdminFolderSDKコマンドレットを使用してフォルダーを作成し、それをApplicationsノードの下に表示させたい場合は、Set-BrokerAdminFolderMetadataコマンドレットを使用してContainsApplicationsメタデータを追加する必要があります。例:
Set-BrokerAdminFolderMetadata -AdminFolderId {adminFolderUid} -Name ContainsApplications -Value true <!--NeedCopy-->
アプリケーションフォルダーを管理するには、左側のペインでアプリケーションを選択します。以下のリストを参考にしてください。
- すべてのフォルダーを表示するには(ネストされたフォルダーを除く): フォルダーリストの上にあるすべて表示をクリックします。
- 最上位レベルにフォルダーを作成するには(ネストしない): アプリケーションフォルダーを選択します。新しいフォルダーをアプリケーション以外の既存のフォルダーの下に配置する場合は、そのフォルダーを選択します。次に、アクションバーでフォルダーの作成を選択します。名前を入力します。
- フォルダーを移動するには: フォルダーを選択し、アクションバーでフォルダーの移動を選択します。ネストされたフォルダーが含まれていない限り、一度に1つのフォルダーしか移動できません。(フォルダーを移動する最も簡単な方法は、ドラッグすることです。)
- フォルダーの名前を変更するには: フォルダーを選択し、アクションバーでフォルダー名の変更を選択します。名前を入力します。
- フォルダーを削除するには: フォルダーを選択し、アクションバーでフォルダーの削除を選択します。アプリケーションや他のフォルダーを含むフォルダーを削除すると、それらのオブジェクトも削除されます。アプリケーションを削除すると、デリバリーグループからのアプリケーションの割り当てが削除されます。ただし、マシンからは削除されません。
- アプリケーションをフォルダーに移動するには: 1つまたは複数のアプリケーションを選択します。次に、アクションバーでアプリケーションの移動を選択します。フォルダーを選択します。
デリバリーグループまたはアプリケーショングループを作成する際に、アプリケーションページで追加するアプリケーションをフォルダーに配置することもできます。デフォルトでは、追加されたアプリケーションはアプリケーションフォルダーに入ります。フォルダーを選択または作成するには、変更をクリックします。
公開デスクトップでのアプリケーションのローカル起動を制御する
ユーザーが公開デスクトップ内から公開アプリケーションを起動するときに、そのアプリケーションをデスクトップセッション内で起動するか、公開アプリケーションとして起動するかを制御できます。Citrix Workspaceアプリは、VDA上のWindowsレジストリでアプリケーションのインストールパスを検索し、存在する場合はアプリケーションのローカルインスタンスを起動します。それ以外の場合は、ホストされたアプリケーションのインスタンスが起動されます。VDAにインストールされていないアプリケーションを起動すると、ホストされたアプリケーションが起動されます。詳細については、「vPrefer起動」を参照してください。
PowerShell(Citrix Cloud展開ではRemote PowerShell SDKを使用し、オンプレミス展開ではPowerShell SDKを使用)で、このアクションを変更できます。
New-BrokerアプリケーションまたはSet-BrokerApplicationコマンドレットで、LocalLaunchDisabledオプションを使用します。例:
Set-BrokerApplication -LocalLaunchDisabled <Boolean>
デフォルトでは、このオプションの値はfalse(-LocalLaunchDisabled $false)です。公開デスクトップ内から公開アプリケーションを起動すると、アプリケーションはそのデスクトップセッション内で起動されます。
オプションの値をtrue(-LocalLaunchDisabled $true)に設定すると、公開アプリケーションが起動されます。これにより、公開デスクトップ(Windows向けCitrix Workspaceアプリを使用)から公開アプリケーションへの個別の追加セッションが作成されます。
要件と制限:
- アプリケーションの
ApplicationType値はHostedOnDesktopである必要があります。 - このオプションは、適切なPowerShell SDKを介してのみ利用できます。現在、Web Studioのグラフィカルインターフェイスでは利用できません。
- このオプションには最低限、ストアフロント 3.14、Citrix Receiver for Windows 4.11、および デリバリーコントローラー 7.17 が必要です。
この記事の概要
- はじめに
- アプリケーションの追加
- アプリケーションのグループ関連付けを変更する
- アプリケーションを複製、有効化または無効化、名前変更、または削除する
- デリバリーグループからアプリケーションを削除する
- アプリケーショングループからアプリケーションを削除する
- アプリケーションプロパティの変更
- アプリケーション制限の構成
- 公開アプリケーションにパラメーターを渡す
- 公開アプリケーションでのセッションサインアウトの問題のトラブルシューティング
- 公開されたアプリケーションを開くときにWindowsの免責事項メッセージをフルサイズで表示するようにLogonUIを変更する方法
- アプリケーションフォルダーの管理
- 公開デスクトップでのアプリケーションのローカル起動を制御する