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