データ粒度と保持
データ値の集計
Monitor Service は、ユーザーセッションの使用状況、ユーザーログオンパフォーマンスの詳細、セッションの負荷分散の詳細、および接続とマシンの障害情報など、さまざまなデータを収集します。データはカテゴリに応じて異なる方法で集計されます。OData Method API を使用して提示されるデータ値の集計を理解することは、データを解釈するために不可欠です。例:
- 接続されたセッションとマシンの障害は、ある期間に発生します。したがって、それらは期間中の最大値として公開されます。
- ログオン期間は時間の長さを測定するものであるため、期間中の平均として公開されます。
- ログオン数と接続障害は、ある期間に発生した回数であるため、期間中の合計として公開されます。
同時データの評価
セッションは、同時と見なされるためには重複している必要があります。ただし、時間間隔が1分の場合、その1分間のすべてのセッション(重複しているかどうかにかかわらず)は同時と見なされます。間隔のサイズが非常に小さいため、精度を計算するのに伴うパフォーマンスオーバーヘッドは、追加される価値に見合いません。セッションが同じ時間内に発生しても、同じ分内に発生しない場合、それらは重複しているとは見なされません。
サマリーテーブルと生データの相関
データモデルは、メトリックを2つの異なる方法で表します。
- サマリーテーブルは、分、時間、日単位の時間粒度でメトリックの集計ビューを表します。
- 生データは、セッション、接続、アプリケーション、およびその他のオブジェクトで追跡される個々のイベントまたは現在の状態を表します。
API呼び出し間またはデータモデル自体内でデータを関連付けようとするときは、以下の概念と制限を理解することが重要です。
- 部分的な間隔のサマリーデータはありません。 メトリックのサマリーは、長期間にわたる履歴トレンドのニーズを満たすように設計されています。これらのメトリックは、完全な間隔でサマリーテーブルに集計されます。データ収集の開始時(利用可能な最も古いデータ)または終了時の部分的な間隔には、サマリーデータはありません。1日の集計(Interval=1440)を表示する場合、これは最初と最新の不完全な日にはデータがないことを意味します。これらの部分的な間隔には生データが存在する可能性がありますが、決して集計されません。特定のデータ粒度について、特定のサマリーテーブルから最小および最大の SummaryDate を取得することで、最も早い集計間隔と最も遅い集計間隔を決定できます。SummaryDate 列は間隔の開始を表します。Granularity 列は、集計データの期間の長さを表します。
- 時間による相関。 メトリックは、前述のセクションで説明されているように、完全な間隔でサマリーテーブルに集計されます。これらは履歴トレンドに使用できますが、生イベントはトレンド分析のために集計されたものよりも現在の状態をより正確に反映している可能性があります。サマリーデータと生データの時間ベースの比較では、発生する可能性のある部分的な間隔や期間の開始と終了にはサマリーデータがないことを考慮する必要があります。
- 見逃されたイベントと潜在的なイベント。 イベントが見逃されたり、集計期間に対して潜在的であったりすると、サマリーテーブルに集計されるメトリックがわずかに不正確になる可能性があります。モニターサービスは正確な現在の状態を維持しようとしますが、見逃されたイベントや潜在的なイベントのために、サマリーテーブルの集計を過去に遡って再計算することはありません。
- 接続の高可用性。 接続の高可用性中、現在の接続のサマリーデータカウントにギャップが生じますが、セッションインスタンスは引き続き生データで実行されます。
- データ保持期間。 サマリーテーブルのデータは、生イベントデータのスケジュールとは異なるグルーミングスケジュールで保持されます。サマリーテーブルまたは生テーブルからグルーミングによってデータが削除されたため、データが欠落している可能性があります。また、サマリーデータの粒度によって保持期間が異なる場合があります。粒度の低いデータ(分単位)は、粒度の高いデータ(日単位)よりも早くグルーミングされます。グルーミングによってある粒度からデータが欠落している場合でも、より高い粒度で見つかる可能性があります。API呼び出しは要求された特定の粒度のみを返すため、ある粒度でデータが受信されないからといって、同じ期間のより高い粒度でデータが存在しないという意味ではありません。
- タイムゾーン。 メトリックはUTCタイムスタンプで保存されます。サマリーテーブルは、時間単位のタイムゾーン境界で集計されます。時間単位の境界に該当しないタイムゾーンの場合、データが集計される場所に関して多少の不一致が生じる可能性があります。
データの粒度と保持
Directorによって取得される集計データの粒度は、要求された時間 (T) スパンの関数です。ルールは次のとおりです。
- 0 < T <= 1時間 - 分単位の粒度を使用
- 0 < T <= 30日 - 時間単位の粒度を使用
- T > 31日 - 日単位の粒度を使用
集計データから取得されない要求データは、生のセッションおよび接続情報から取得されます。このデータは急速に増加する傾向があるため、独自のグルーミング設定があります。グルーミングにより、関連データのみが長期的に保持されます。グルーミングは、レポートに必要な粒度を維持しながら、より良いパフォーマンスを保証します。Premiumライセンスサイトのお客様は、グルーミング保持を希望する保持日数に変更できます。変更しない場合はデフォルトが使用されます。サイトデータベースとの接続が失われた場合、モニターサービスは以下の表で指定されているPremiumエンタイトルメントのデフォルトの保持日数を使用します。
設定にアクセスするには、Delivery Controller™で次のPowerShellコマンドを実行します。
asnp Citrix.*
Get-MonitorConfiguration
Set-MonitorConfiguration -<setting name> <value>
<!--NeedCopy-->
| 設定名 | 影響を受けるグルーミング | Premiumの保持日数 | アドバンストの保持日数 | ||
|---|---|---|---|---|---|
| 1 | セッション保持日数 | セッション終了後のセッションおよび接続レコードの保持 | 90 | 31 | |
| 2 | グルーミング障害保持日数 | マシン障害ログおよび接続障害ログのレコード | 90 | 31 | |
| 3 | ロードインデックス保持日数 | ロードインデックスのレコード | 90 | 31 | |
| 4 | 整理済み削除保持日数 | LifecycleStateが「Deleted」であるマシン、カタログ、デスクトップグループ、およびハイパーバイザーのエンティティ。この設定は、関連するセッション、セッション詳細、概要、障害、またはロードインデックスのレコードも削除します。 | 90 | 31 | |
| 5 | 整理済みサマリー保持日数 | デスクトップグループサマリー、障害ログサマリー、およびロードインデックスサマリーのレコード。集計データ - 日次粒度。 | 365 | 31 | |
| 6 | マシンのホットフィックスログ保持日数 | VDAおよびコントローラーマシンに適用されたホットフィックス | 90 | 31 | |
| 7 | グルームミニットリテンションデイズ | 集計データ - 分単位の粒度 | 3 | 3 | |
| 8 | グルームアワリーリテンションデイズ | 集計データ - 時間単位の粒度 | 32 | 31 | |
| 9 | グルームアプリケーションインスタンスリテンションデイズ | アプリケーションインスタンスの履歴 | 90 | 該当なし | |
| 10 | 通知ログの整理保持日数 | 通知ログレコード | 90 | 該当なし | |
| 11 | リソース使用状況生データの整理保持日数 | リソース使用率データ - 生データ | 3 | 3 | |
| 12 | リソース使用状況分データの整理保持日数 | リソース使用率サマリーデータ - 分単位の粒度 | 7 | 7 | |
| 13 | リソース使用状況時間データの整理保持日数 | リソース使用率サマリーデータ - 時間単位 | 30 | 30 | |
| 14 | リソース使用状況日データの整理保持日数 | リソース使用率サマリーデータ - 日単位 | 365 | 31 | |
| 15 | プロセス使用状況生データの整理保持日数 | プロセス使用率データ - 生データ | 1 | 1 | |
| 16 | プロセス使用状況分単位データの整理保持日数 | プロセス利用状況データ - 分単位の粒度 | 3 | 3 | |
| 17 | プロセス使用状況の時間データ整理保持日数 | プロセス利用状況データ - 時間単位の粒度 | 7 | 7 | |
| 18 | プロセス使用状況の日データ整理保持日数 | プロセス利用状況データ - 日単位の粒度 | 30 | 30 | |
| 19 | グルームセッションメトリクスデータリテンションデイズ | セッションメトリックデータ | 1 | 1 | |
| 20 | グルームマシンメトリックデータリテンションデイズ | マシンメトリックデータ | 3 | 3 | |
| 21 | グルームマシンメトリックデイサマリーデータリテンションデイズ | マシンメトリックサマリーデータ | 365 | 31 | |
| 22 | アプリケーションエラーの整理保持日数 | アプリケーションエラーデータ | 1 | 1 | |
| 23 | アプリケーション障害の整理保持日数 | アプリケーション障害データ | 1 | 1 | |
注意:
Monitor Serviceデータベースの値を変更した場合、新しい値を有効にするにはサービスを再起動する必要があります。Monitor Serviceデータベースへの変更は、Citrixサポートの指示の下でのみ行うことをお勧めします。
GroomProcessUsageRawDataRetentionDays、GroomResourceUsageRawDataRetentionDays、およびGroomSessionMetricsDataRetentionDaysの設定は、デフォルト値の1に制限されており、GroomProcessUsageMinuteDataRetentionDaysはデフォルト値の3に制限されています。プロセス使用状況データは急速に増加する傾向があるため、これらの値を設定するPowerShellコマンドは無効になっています。 また、ライセンスベースの保持設定は次のとおりです。
- Premiumライセンスサイト - すべての設定のグルーミング保持期間は1000日(Citrixは365日を推奨)に制限されています。
- Advancedライセンスサイト - すべての設定のグルーミング保持期間は31日に制限されています。
- その他のすべてのサイト - すべての設定のグルーミング保持期間は7日間に制限されます。
例外:
- GroomApplicationInstanceRetentionDays の設定は、Premium ライセンスが適用されているサイトでのみ行うことができます。
- GroomApplicationErrorsRetentionDays および GroomApplicationFaultsRetentionDays の設定可能な期間は、プレミアムライセンスが適用されている環境のサイトにおいては、31日間に制限されます。
長期間データを保持すると、テーブルサイズに以下の影響があります。
-
時間単位のデータ。 時間単位のデータが最長2年間データベースに保持される場合、1000のデリバリーグループを持つサイトでは、データベースが次のように増大する可能性があります。
1000のデリバリーグループ x 1日あたり24時間 x 1年あたり365日 x 2年間 = 17,520,000行のデータ。集計テーブルにこれほど大量のデータがあると、パフォーマンスへの影響は甚大です。ダッシュボードデータはこのテーブルから取得されるため、データベースサーバーへの要件は大きくなる可能性があります。過度に大量のデータは、パフォーマンスに劇的な影響を与える可能性があります。
-
セッションおよびイベントデータ。 セッションが開始され、接続/再接続が行われるたびに収集されるデータ。大規模なサイト(10万ユーザー)の場合、このデータは急速に増大します。たとえば、これらのテーブルの2年分のデータは1TBを超える量になり、ハイエンドのエンタープライズレベルのデータベースが必要になります。