コアコンセプト
Always on Tracing (AOT) アーキテクチャは、Citrix Virtual Apps and Desktops (CVAD) および DaaS 環境全体で継続的なリアルタイムログ収集を提供するように設計されています。これにより、IT 管理者と Citrix サポートは、手動でのログ開始や問題の再現を必要とせずに、ユーザーおよびインフラストラクチャの問題をトラブルシューティングできます。
AOT システムは、複数の Citrix インフラストラクチャ層からログをキャプチャ、転送、保存するために順次動作する、いくつかの統合されたコンポーネントで構築され、一元化されたリポジトリに格納されます。
主要コンポーネントとワークフロー
-
AOTログジェネレーター (Citrixコアコンポーネント): Virtual Delivery Agent (VDA)、Delivery Controller (DDC)、StoreFrontなどのCitrixコンポーネントは、ログジェネレーターとして機能します。これらのコンポーネントには、テレメトリーサービスまたは同様のサービスが搭載されており、AOT APIを使用して、トレースデータをキャプチャし、事前定義されたステップトレースを記録し、ユーザーセッションとトランザクションに関連するエラーイベントをログに記録します。
-
ログ収集の有効化: 管理者がログ収集のリクエストを開始すると (通常、Web Studioの設定を通じて行われ、指示はサイトデータベースに保存され、ブローカーに送信されます。ブローカーは、ブローカー、StoreFront、VDAなどの関連コンポーネント全体でログ収集プロセスを調整します)、管理者は、Session Recording、PVS、FASなどの他のコンポーネントからPowerShellコマンドを通じて個別にログ収集のリクエストを開始します。
-
テレメトリーサービス: Citrix Web Studioでログサーバーアドレスを設定し、設定が伝播されると、各コンポーネントのテレメトリーサービスは、新しいリアルタイムAOTリスナーをアクティブ化します。これは、事前定義されたイベント、障害、またはトリガーポイントに基づいてログを収集します。
-
集中ログサーバーへのログ転送: ログが収集されると、テレメトリーサービスまたは独立したサービスが、それらを直接集中ログサーバーに安全に転送します。エンドポイントがCitrix Gatewayを介して外部ネットワークから接続されている環境では、転送は通常、安全でシームレスな転送を確保するためにSOCKSトンネルを介して行われます。
-
ログの保存と整理: 集中ログサーバーはAOTログを受信、解析、保存します。これらは、インデックス付きデータベースバックエンド (デフォルトではOpenSearch) を使用して、構造化され検索可能な形式で保存されます。ログはセッション、コンポーネント、タイムスタンプでタグ付けされ、これにより、容易なアクセスと効率的なトラブルシューティングが可能になります。
Citrix AOT システム内のログは、構造化され検索可能な形式で保存され、容易なアクセスと効率的なトラブルシューティングを可能にするために、さまざまなフィールドでタグ付けされています。これらのタグには以下が含まれます。
- MachineName: ログが生成されたマシンの名前。
- MachineIP: マシンのIPアドレス。
- 役割: Citrixコンポーネント(例:VDA、DDC、StoreFrontなど)が果たす機能。
- TimeStamp: ログイベントが発生したUTCタイムスタンプ。
- Message: 実際のログメッセージの内容。単語で検索/フィルタリングできます。
- レベル: ログの重大度レベル (例: 情報、警告、エラー)。
- モジュール: ログを生成した特定のソフトウェアモジュール。
- プロセス名: ログを生成したプロセスの名前。
- プロセスID: プロセスのID。
- スレッド: プロセス内のスレッドID。
- CPU: ログ記録時のCPU IDに関連する情報。
- セッションID: ログに関連付けられたユーザーセッションのID。
- クラス: モジュール内のクラスまたはコンポーネント。
これらの詳細なタグにより、管理者は特定の基準に基づいてログを迅速にフィルタリング、検索、分析し、問題の特定と解決を容易にすることができます。
まとめると、AOTワークフローはCitrixコンポーネントがログを生成することから始まります。これらのログを収集するために一元的なリクエストが開始され、Telemetry Serviceが関連コンポーネントからそれらを収集します。収集されたログは、インデックス作成、保存、およびその後の分析のために、一元化されたログサーバーに安全に転送されます。
AOTの仕組み
Citrix Always on Tracing (AOT) は、環境内の主要なコンポーネントからログデータを継続的に取得します。トリガーされると、ログは自動的に収集され、一元化されたログサーバーに安全に転送され、分析のために保持されます。これにより、手動でのトレースが不要になり、トラブルシューティングが簡素化されます。
トレースのトリガーとログ収集: VDA、DDC、StoreFrontなどのCitrixコンポーネントは、重要な手順とエラーを追跡するためのAOT APIを搭載しています。これらのコンポーネントはAOTログジェネレーターとして機能します。管理者がDelivery Controllerからログ収集リクエストを開始すると、次のようになります。
- DDCは関連するCitrixコンポーネントに指示を送信します。各コンポーネントは、そのローカルのTelemetry Serviceにリクエストを転送します。
- Telemetry Serviceは、AOTログを収集するためにリアルタイムAOTリスニングプログラムを開始し、ログを一元化されたログサーバーに転送します。
ログの保存と保持: AOTログが受信されると、中央ログサーバーはそれらを構造化された検索可能なデータベースにフォーマットし、インデックス化します。ログは、ストレージ使用量を最適化するために、定義された保持ポリシーに基づいて保持されます。デフォルトでは、AOTログは7日間保持され、その後、スペースを節約するために自動的にパージされます。
AOTと従来のログ記録の比較
| 側面 | AOT | 従来のCDFトレース |
|---|---|---|
| アクティベーション | 自動、継続的 | 手動、問題の再現が必要 |
| 複雑さ | ユーザーフレンドリーで読みやすいログ | エンジニアリングレベルの解析 |
| 診断速度 | 即座にログが利用可能 | 再現作業によって遅延 |
| リソース使用量 | 最適化されたバッファによる低オーバーヘッド | 誤って使用すると中程度から高程度 |
従来のトレースツールは手作業が必要で、問題が発生している最中に捕捉した場合にのみ機能します。AOTを使用すると、ログはバックグラウンドで継続的に実行されるため、監視していなくても問題が発生したときに捕捉されます。これにより、時間を節約し、トラブルシューティングがはるかに容易になります。
AOTのハイライト
- 常時稼働: トレースは常に実行され、手動でオンにする必要はありません。
- 自動キャプチャ: 問題が発生すると常にログが収集されます。
- 中央ログサーバー: すべてのログは一箇所に保存され、簡単にアクセスできます。
- トラブルシューティングの簡素化: 一般的な障害を迅速に特定するのに役立ちます。
- 再現不要: 問題を再現する必要はありません。すでに捕捉されています。