グラフィックの構成と微調整
この記事では、Linux VDAのグラフィックの構成と微調整について説明します。
詳細については、「システム要件」および「インストール概要」セクションを参照してください。
構成
3Dグラフィックワークロードの最適化
-
この設定は、グラフィックを多用するワークロードに最適なデフォルト値を構成します。ワークロードがグラフィックを多用するアプリケーションに集中しているユーザーに対して、この設定を有効にします。このポリシーは、セッションでGPUが利用可能な場合にのみ適用してください。このポリシーによって設定されたデフォルト設定を明示的に上書きするその他の設定は、すべて優先されます。
-
デフォルトでは、3Dグラフィックワークロードの最適化は無効になっています。
圧縮用ビデオコーデック
- Thinwireは、Linux VDAで使用されるディスプレイリモートテクノロジーです。このテクノロジーにより、あるマシンで生成されたグラフィックを、通常はネットワーク経由で別のマシンに送信して表示できます。
圧縮用ビデオコーデックの使用グラフィックポリシーは、デフォルトのグラフィックモードを設定し、さまざまなユースケースに対応する以下のオプションを提供します。
- 優先する場合にのみ使用。この設定がデフォルトです。追加の構成は必要ありません。これにより、すべてのCitrix®接続でThinwireが選択され、標準的なデスクトップワークロードのスケーラビリティ、帯域幅、および優れた画質のために最適化されます。
- 画面全体。フルスクリーンH.264またはH.265でThinwireを提供し、特に3Dグラフィックを多用する場合に、ユーザーエクスペリエンスと帯域幅の向上を最適化します。画面全体が選択されている場合、または優先する場合にのみ使用が選択され、3Dグラフィックワークロードの最適化が有効になっている場合、セッションウォーターマークがサポートされます。
-
アクティブに変更される領域。Thinwireのアダプティブディスプレイテクノロジーは、動的な画像(ビデオ、移動中の3D)を識別します。画像が動いている画面の一部でのみ、AV1、H.265、またはH.264を使用します。AV1、H.265、またはH.264ビデオコーデックを選択的に使用することで、HDX Thinwireは頻繁に更新される画面の一部を検出してエンコードできます。静止画圧縮(JPEG、RLE)とビットマップキャッシュは、テキストや写真画像を含む画面の残りの部分で引き続き使用されます。ユーザーは、低い帯域幅消費と、ロスレステキストまたは他の場所での高品質画像と組み合わせたビデオコンテンツのより良い品質という利点を得られます。Visual qualityポリシーがAlways LosslessまたはBuild to Losslessに設定されている場合、AV1およびH.265の選択的な使用はサポートされません。

以下の視覚表示ポリシー設定を含むその他のポリシー設定は、ディスプレイリモートのパフォーマンスを微調整するために使用できます。
- 簡易グラフィックの優先色深度
- ターゲットフレームレート
-
AV1/H.265/H.264ハードウェアエンコーディング
-
ビデオコーデックのハードウェアエンコーディングの使用ポリシーは、利用可能な場合、GPUハードウェアアクセラレーションを使用してビデオコーデックで画面要素を圧縮することを許可します。GPUハードウェアアクセラレーションは、ハードウェアリソースの利用を最適化し、フレーム/秒(FPS)のパフォーマンスを大幅に向上させます。
- GPUハードウェアアクセラレーションは、圧縮用ビデオコーデックの使用ポリシーによって設定されたすべてのグラフィックモードをカバーします。
- 優先する場合にのみ使用
-
画面全体
-
アクティブに変更される領域
-
ハードウェアビデオ圧縮を有効にするには、以下の手順を完了します。
-
- ビデオコーデックのハードウェアエンコーディングの使用ポリシーをEnabledに設定します。
-
圧縮用ビデオコーデックの使用を優先する場合にのみ使用、画面全体、またはアクティブに変更される領域に設定します。ビデオコーデックを使用しないに設定されていないことを確認してください。
- 使用可能にするには、AV1またはH.265ビデオコーデックがVDAとCitrix Workspaceアプリの両方でサポートされ、有効になっている必要があります。コーデックネゴシエーション中、AV1はH.265およびH.264よりも優先されます。AV1がサポートされていない場合、H.265がネゴシエートされます。AV1とH.265の両方がサポートされていない場合、セッションはH.264ビデオコーデックの使用にフォールバックします。GPUハードウェアが利用できない場合、VDAはソフトウェアビデオコーデックを使用したCPUベースのエンコーディングにフォールバックします。
AV1ハードウェアエンコーディングの要件
VDA
- VDA:2311以降
- GPU:NVIDIA Ada Lovelace以降(NVIDIA GPUがサポートするビデオコーデックのマトリックスについては、https://developer.nvidia.com/video-encode-and-decode-gpu-support-matrix-newのNVIDIAドキュメントを参照してください。)
- NVIDIAグラフィックドライバー522.25以降(Video Codec SDK v12.0)
クライアント
- Citrix Workspace™アプリ2305 for Windows以降
- AV1デコーディングをサポートするクライアントGPU:
- NVIDIA Ampere以降
- Intel第11世代/Arc以降
- AMD Radeon RX 6000/Radeon Pro W6000シリーズ(RDNA2)以降
H.265ハードウェアエンコーディングの要件
クライアント
- Citrix Receiver for Windows 4.10~4.12
-
Citrix Workspaceアプリ1808 for Windows以降
- クライアントでH.265ハードウェアエンコーディングを有効にするには、「H.265ビデオエンコーディング」を参照してください。
H.265/H.264ロスレス圧縮
H.265/H.264ロスレス圧縮は、NVIDIA GPUによるHDX 3D PROハードウェアアクセラレーションで利用可能です。H.265ロスレス圧縮には、Citrix Workspaceアプリ2305 for Windows以降が必要です。H.264ロスレス圧縮には、以下のクライアントが必要です。
- Citrix Workspaceアプリ2303 for Windows以降
- Apple M1チップを搭載したCitrix Workspaceアプリ2301 for Mac以降
H.265/H.264ロスレス圧縮を有効にするには、以下の手順を完了します。
- ビデオコーデックのハードウェアエンコーディングの使用ポリシーをEnabledに設定します。
-
圧縮用ビデオコーデックの使用ポリシーを画面全体に設定します。
- Visual qualityポリシーをAlways LosslessまたはBuild to Losslessに設定します。
視覚的にロスレスな圧縮を許可
視覚的にロスレスな圧縮を許可ポリシーは、グラフィックに対して、真のロスレス圧縮の代わりに視覚的にロスレスな圧縮を使用することを許可します。視覚的にロスレスな圧縮は、真のロスレスよりもパフォーマンスが向上しますが、目視では気づかない程度のわずかな損失があります。この設定は、Visual quality設定の値の使用方法を変更します。
視覚的にロスレスな圧縮を許可ポリシーは、デフォルトで無効になっています。視覚的にロスレスな圧縮を有効にするには、視覚的にロスレスな圧縮を許可をEnabledに設定し、Visual qualityポリシーをBuild to Losslessに設定します。
圧縮用ビデオコーデックの使用ポリシーがビデオコーデックを使用しないに設定されている場合、視覚的にロスレスな圧縮は静止画エンコーディングに適用されます。圧縮用ビデオコーデックの使用ポリシーがビデオコーデックを使用しない以外のグラフィックモードに設定されている場合、視覚的にロスレスな圧縮はH.264エンコーディングに適用されます。
視覚品質およびビデオコーデックを使用した圧縮ポリシー設定の詳細については、視覚表示ポリシー設定およびグラフィックポリシー設定を参照してください。
グラフィック品質スライダー
仮想Linuxセッションで実行されるグラフィックステータスインジケーターツールに、グラフィック品質スライダーを組み込みました。このスライダーは、画像品質と対話性の適切なバランスを見つけるのに役立ちます。
スライダーを使用するには、次の手順を実行します。
-
Citrix Studioでグラフィックステータスインジケーターポリシーを有効にします。

-
ターミナルを開き、
ctxsliderコマンドを実行します。スライダーUIが表示されます。注:
-
視覚品質ポリシーを常にロスレスまたはロスレスにビルドに設定している場合、スライダーUIは表示されません。
-
ターミナルとシステムトレイの両方からスライダーUIを起動できます。

次の選択肢が利用可能です。
- 画像品質を変更するには、スライダーを移動します。スライダーは0~9の範囲をサポートします。
- システム定義の設定を使用するには、システムに決定させるを選択します。
- ロスレスモードに切り替えるには、ピクセルパーフェクトを選択します。
-
帯域幅の見積もりに基づく平均ビットレートの調整
Citrixは、帯域幅の見積もりに基づいて平均ビットレートを調整することで、HDX™ 3D Proハードウェアエンコーディングを強化します。
HDX 3D Proハードウェアエンコーディングが使用されている場合、VDAはネットワークの帯域幅を断続的に見積もり、それに応じてエンコードされたフレームのビットレートを調整できます。この新機能は、シャープネスと流暢さのバランスを取るためのメカニズムを提供します。
この機能はデフォルトで有効になっています。無効にするには、次のコマンドを実行します。
sudo /opt/Citrix/VDA/bin/ctxreg create -k "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Citrix\Thinwire" -t "REG_DWORD" -v "DisableReconfigureEncoder" -d "0x00000001" --force
<!--NeedCopy-->
この機能を使用することに加えて、シャープネスと流暢さの間で調整するために次のコマンドも実行できます。AverageBitRatePercentおよびMaxBitRatePercentパラメーターは、帯域幅使用率のパーセンテージを設定します。設定する値が高いほど、グラフィックはよりシャープになり、流暢さは低下します。推奨設定範囲は50~100です。
sudo /opt/Citrix/VDA/bin/ctxreg create -k "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Citrix\Thinwire" -t "REG_DWORD" -v "AverageBitRatePercent" -d "90" --force
sudo /opt/Citrix/VDA/bin/ctxreg create -k "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Citrix\Thinwire" -t "REG_DWORD" -v "MaxBitRatePercent" -d "100" --force
<!--NeedCopy-->
平均ビットレート調整において、画面が静止している場合、新しいフレームが送信されないため、最新のフレームは低品質の状態を維持します。シャープ化サポートは、最新のフレームを最高品質で再構成し、即座に送信することでこの問題に対処できます。
Linux VDA Thinwireでサポートされているポリシーの完全なリストについては、ポリシーサポートリストを参照してください。
Linux VDAでのマルチモニターサポートの構成に関する情報については、CTX220128を参照してください。
並列処理
Thinwireは、特定のタスクを並列化することで、1秒あたりのフレーム数(FPS)を向上させることができますが、全体的なCPU消費量がわずかに高くなるというオーバーヘッドを伴います。この機能はデフォルトで無効になっています。この機能を有効にするには、VDAで次のコマンドを実行します。
sudo /opt/Citrix/VDA/bin/ctxreg create -k "HKLM\System\CurrentControlSet\Control\Citrix\Thinwire" -t "REG_DWORD" -v "ParallelProcessing" -d "0x00000001" --force
<!--NeedCopy-->
トラブルシューティング
使用中のグラフィックモードの確認
使用中のグラフィックモードを確認するには、次のコマンドを実行します(0はTW+、1は全画面ビデオコーデックを意味します)。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep GraphicsMode
<!--NeedCopy-->
結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "GraphicsMode" -d "0x00000000" --force
AV1の使用状況の確認
注:
現在のセッションで使用されているビデオコーデックを確認するには、以下に示すコマンドを実行するか、システムトレイからグラフィックステータスを確認します。
AV1が使用されていることを確認するには、次のコマンドを実行します(0は未使用、1は使用中を意味します)。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep AV1
<!--NeedCopy-->
例えば、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "AV1" -d "0x00000000" --force
H.265の使用状況の確認
全画面H.265が使用されていることを確認するには、次のコマンドを実行します(0は未使用、1は使用中を意味します)。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep H265
<!--NeedCopy-->
例えば、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "H265" -d "0x00000000" --force
H.264の使用状況の確認
H.264が使用されていることを確認するには、次のコマンドを実行します(0は未使用、1は使用中を意味します)。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep H264
<!--NeedCopy-->
例えば、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "H264" -d "0x00000000" --force
使用中のYUVエンコーディングスキームの確認
使用中のYUVエンコーディングスキームを確認するには、次のコマンドを実行します(0はYUV420、1はYUV422、2はYUV444を意味します)。
注:
YUVFormatの値は、ビデオコーデックが使用されている場合にのみ意味があります。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep YUVFormat
<!--NeedCopy-->
たとえば、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "YUVFormat" -d "0x00000000" --force
YUV444ソフトウェアエンコーディングの使用状況の確認
YUV444ソフトウェアエンコーディングが使用されていることを確認するには、次のコマンドを実行します。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep Graphics
<!--NeedCopy-->
YUV444が使用されている場合、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "GraphicsMode" -d "0x00000001" --force
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "H264" -d "0x00000001" --force
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "HardwareEncoding" -d "0x00000000" --force
create -k "HKLM\Software\Citrix\Ica\Session\4\Graphics" -t "REG_DWORD" -v "YUVFormat" -d "0x00000002" --force
HDX 3D Proの有効化の確認
HDX 3D Proが有効になっていることを確認するには、次のコマンドを実行します。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep ProductEdition
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep StackSessionMode
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep 3DPro
<!--NeedCopy-->
HDX 3D Proが有効になっている場合、結果は次のようになります。
create -k "HKLM\Software\Citrix\VirtualDesktopAgent\State" -t "REG_SZ" -v "ProductEdition" -d "<PLT or ENT>" --force
create -k "HKLM\System\CurrentControlSet\Control\Citrix\WinStations\tcp" -t "REG_DWORD" -v "StackSessionMode" -d "0x00000000" --force
create -k "HKLM\System\CurrentControlSet\Control\Citrix" -t "REG_DWORD" -v "3DPro" -d "0x00000000" --force
HDX 3D Proに必要なNVIDIAライブラリがロードされていることを確認するには、Linux VDAで nvidia-smi コマンドを実行します。結果は次のようになります。
Tue Apr 12 10:42:03 2016
+------------------------------------------------------+
| NVIDIA-SMI 361.28 Driver Version: 361.28 |
|-------------------------------+----------------------+----------------------+
| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |
| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |
|===============================+======================+======================|
| 0 GRID K1 Off | 0000:00:05.0 Off | N/A |
| N/A 42C P0 14W / 31W | 207MiB / 4095MiB | 8% Default |
+-------------------------------+----------------------+----------------------+
+-----------------------------------------------------------------------------+
| Processes: GPU Memory |
| GPU PID Type Process name Usage |
|=============================================================================|
| 0 2164 C+G /usr/local/bin/ctxgfx 106MiB |
| 0 2187 G Xorg 85MiB |
+-----------------------------------------------------------------------------+
<!--NeedCopy-->
3D Proでのハードウェアエンコーディングの使用状況の確認
次のコマンドを実行します(0は未使用、1は使用中を意味します)。
sudo /opt/Citrix/VDA/bin/ctxreg dump | grep HardwareEncoding
<!--NeedCopy-->
3D Proが使用されている場合、結果は次のようになります。
create -k "HKLM\Software\Citrix\Ica\Session\1\Graphics" -t "REG_DWORD" -v "HardwareEncoding" -d "0x00000001" --force
NVIDIA GRIDグラフィックドライバーの正しいインストールの確認
NVIDIA GRIDグラフィックドライバーが正しくインストールされていることを確認するには、nvidia-smi を実行します。結果は次のようになります。
+------------------------------------------------------+
| NVIDIA-SMI 352.70 Driver Version: 352.70 |
|-------------------------------+----------------------+----------------------+
| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |
| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |
|===============================+======================+======================|
| 0 Tesla M60 Off | 0000:00:05.0 Off | Off |
| N/A 20C P0 37W / 150W | 19MiB / 8191MiB | 0% Default |
+-------------------------------+----------------------+----------------------+
+-----------------------------------------------------------------------------+
| Processes: GPU Memory |
| GPU PID Type Process name Usage |
|=============================================================================|
| No running processes found |
+-----------------------------------------------------------------------------+
<!--NeedCopy-->
カードの正しい構成を設定します。
etc/X11/ctx-nvidia.sh
HDX 3D Proマルチモニターの再描画に関する問題
プライマリモニター以外の画面で再描画の問題が発生している場合は、NVIDIA GRIDライセンスが利用可能であることを確認してください。
Xorgエラーログの確認
Xorgのログファイルは、/var/log/ フォルダーに Xorg.{DISPLAY}.log のような名前で保存されています。
既知の問題と制限事項
vGPUの場合、XenServer(旧Citrix Hypervisor™)ローカルコンソールにICAデスクトップセッション画面が表示される
回避策:次のコマンドを実行して、VMのローカルVGAコンソールを無効にします。
[root@xenserver® ~]# xe vgpu-param-set uuid=vgpu-uuid extra_args=disable_vnc=1
<!--NeedCopy-->
ログオン時のGnome 3デスクトップポップアップの遅延
これは、Gnome 3デスクトップセッションの起動における制限事項です。
Citrix Workspaceアプリウィンドウのサイズ変更時に一部のOpenGL/WebGLアプリケーションがうまくレンダリングされない
Citrix Workspaceアプリのウィンドウのサイズを変更すると、画面の解像度が変わります。NVIDIAプロプライエタリドライバーは一部の内部状態を変更するため、アプリケーションがそれに応じて応答する必要がある場合があります。たとえば、WebGLライブラリ要素 lightgl.js は、「このテクスチャへのレンダリングはサポートされていません(不完全なフレームバッファ)」というエラーを発生させる可能性があります。