背景情報 最近、Windows パフォーマンスに関する本を読み直しています。以前は SCOM 監視を使用していた私のような怠け者にとって、Zabbix に付属する Windows OS テンプレートは本当に不十分です。以前の SCOM 監視パッケージ (Microsoft が公開したもので、すべての作業が実行され、必要に応じてルールとアラームを有効にするだけで済みました) が役に立たなかったからです。 デフォルトの Zabbix パフォーマンス データには Avg Latency しかなく、平均データは正確ではありません。ディスクのレイテンシと IOPS を確認したい場合は、自分で行う必要があります。Zabbix の Windows パフォーマンス カウンターの構文を確認した後、少し後退しました。すべての数値パフォーマンス カウンターの CounterCategory と CounterName。 内蔵ディスクに関連する唯一の統計は、転送速度と平均遅延です。 Zabbix での Windows パフォーマンス監視 監視する他のパフォーマンス カウンターがある場合、それらの名前と機能は何ですか?すぐに検索できるリストはありますか? 解決する 幸いなことに、PowerShell は簡単に記述できるので、Zabbix のパフォーマンス カウンターの構文を統合する次の関数を作成しました。 関数 Get-PerfCounterDesc{ [コマンドレットバインディング()] パラメータ( [スイッチ]$表示 ) $Categories = [System.Diagnostics.PerformanceCounterCategory]::GetCategories() $SingleInstanceCategories = $Categories | Where-Object {$_.CategoryType -eq "SingleInstance"} $MultiInstanceCategories = $Categories| Where-Object {$_.CategoryType -eq "MultiInstance"} $SingleInstanceCounters = $SingleInstanceCategories | ForEach-Object { (新しいオブジェクト System.Diagnostics.PerformanceCounterCategory($_.CategoryName)).GetCounters() } $MultiInstanceCounters = $MultiInstanceCategories | ForEach-Object { $category = 新しいオブジェクト System.Diagnostics.PerformanceCounterCategory($_.CategoryName) $category.InstanceExists('_Total') の場合 $category.GetCounters('_Total') }elseif($category.InstanceExists('合計')){ $category.GetCounters('合計') }それ以外{ $instanceNames = $category.GetInstanceNames() if($instanceNames.count -gt 0){ $category.GetCounters($instanceNames[0]) } } } $AllCounters = $MultiInstanceCounters + $SingleInstanceCounters $key="HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Perflib\009" $counters=Get-ItemPropertyValue -Path $key -Name "counter" $辞書=@{} ($i=0;$i -lt $counters.count;$i=$i+2){ if($counters[$i+1] -かつ -not $Dict.ContainsKey($counters[$i+1])){ $Dict.add($counters[$i+1],$counters[$i]) } } 書き込みデバッグ $dict.keys.count $result=$AllCounters | Sort-Object カテゴリ名、カウンター名| Select-Object カテゴリ名、 カウンターネーム、 @{n="zabbixPerfCounter";e={'perf_counter["\{0}({{#ReplaceThis}})\{1}"]' -f $dict[$_.CategoryName],$dict[$_.Countername]}}, @{n="categoryNum";e={$Dict[$_.CategoryName]}}, @{n="カウンター番号";e={$Dict[$_.カウンター名]}}, カテゴリヘルプ、 カウンターヘルプ 表示する場合 $result|アウトグリッドビュー }それ以外{ $結果 } } どうやって使うの?上記の関数を個人の PowerShell プロファイルに直接追加します。つまり、PowerShell コンソールの 新しい PowerShell を起動し、Get-PerfCounterDesc -show を直接入力します。さまざまな方法で結果をフィルターできます。 zabbixPerfCounter 列は、生成された zabbix で使用されるキーです。{#replaceThis} をカウンターのインスタンス名に置き換えてください。たとえば、_total。 次に、ディスクIOPSとレイテンシを表示するために、Zabbixテンプレートに次のカウンターを追加しました。 アイテムのプロトタイプ アイテム Grafanaもそれに応じて変更する必要があります 要約する 上記は、編集者が紹介したZabbixでのWindowsパフォーマンス監視の方法です。皆様のお役に立てれば幸いです。ご質問がございましたら、メッセージを残していただければ、編集者がすぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。 以下もご興味があるかもしれません:
|
>>: MySQL クエリにおける LIMIT の大きなオフセットによって引き起こされるパフォーマンス低下の分析
序文MySQL は、クライアント/サーバー構造に基づく、高速、高性能、マルチスレッドのオープン ソー...
Vue スキャフォールディングでは、エントリ ファイル main.js の新しい Vue コードに、...
コードを見てみましょう:コードをコピーコードは次のとおりです。 < !DOCTYPE html...
このドキュメントを作成した当時は2019年12月頃で、er2.200が最新バージョンでした。 1.画...
1. ファイルを現在のディレクトリに解凍しますコマンド: tar -zxvf mysql....ta...
1. ul タグには、Mozilla ではデフォルトでパディング値がありますが、IE ではマージン値...
1. パラダイムこのパラダイムの英語名は Normal Form であり、1970 年代にリレーショ...
目次MySQL 8 の WITH クエリについて学ぶ1. 例3. 練習するMySQL 8 の WIT...
違い: 1. InnoDB はトランザクションをサポートしていますが、MyISAM はサポートしてい...
1. 問題MySQL の初期化時に発生する問題は、次のとおりです。 1. 「MSVCR120.dll...
トラブル発生が突然で、業務も迫っていたため、現場のスクリーンショットを撮る時間がありませんでしたので...
新年の初めに、友人の健康と2013年が素晴らしい年となることを心からお祈りいたします。この記事では、...
以前、UDP を使い始めるために簡単な UDP サーバーとクライアントの例を作成しましたが、実際に使...
<テンプレート> <div class="アプリコンテナ"&...
Nginxはバージョン情報を隠すだけでなく、カスタムWebサーバー情報もサポートします。まずは最終的...