筆者在用lr中control監控Windows資源的時候,有時候老是遇到卡死和報錯,因此就發現了Windows自帶的監控神器————perfmon。web
Perfmon提供了圖表化的系統性能實時監視器、性能日誌和警報管理,系統的性能日誌可定義爲二進制文件、文本文件、SQLSERVER表記錄等方式,能夠很方便地使用第三方工具進行性能分析。數據庫
perfmon.exe 文件位於C:\Windows\System32目錄下。 windows
使用方法: 安全
1)開始 - 運行,輸入 perfmon 後回車,便可打開perfmon.exe。 網絡
2)在 perfmon.exe 的左窗格中,單擊「系統監視器」(若是未選中)。工具
3)在右窗格中單擊右鍵或者「+」,而後單擊「添加計數器」。性能
4)在「性能對象」列表中,選擇要在 PerfMon.exe 中顯示其圖形的計數器類別,單擊「添加」。spa
二.經常使用的性能指標命令行
系統的總體性能由許多因素決定,例如CPU利用率、CPU隊列長度、磁盤空間和I/O、內存使用狀況、網絡流量等等。對於實時性要求較高的系統而言,對系統關鍵性指標的有效監控和管理是保證系統高可用性的重要手段,所以,務必制定出明確的系統性能策略規劃,並對這些性能指標進行有效的實時監控。當關鍵性能指標嚴重偏離或者系統發生故障時,應該採起有效手段來準肯定位問題引起的緣由,並經過調優系統配置或改進應用程序等手段來有效提升系統的可用性。線程
表二:經常使用的性能對象與指標 |
||
性能對象 |
計數器 |
提供的信息 |
Processor |
% Idle Time |
% Idle Time 是處理器在採樣期間空閒的時間的百分比 |
Processor |
% Processor Time |
% Processor Time 指處理器用來執行非閒置線程時間的百分比。計算方法是,測量範例間隔內非閒置線程活動的時間,用範例間隔減去該值。這個計數器是處理器活動的主要說明器,顯示在範例間隔時所觀察的繁忙時間平均百分比。 |
Processor |
% User Time |
% User Time 指處理器處於用戶模式的時間百分比。用戶模式是爲應用程序、環境分系統和整數分系統設計的有限處理模式。 |
Memory |
Available Bytes |
Available Bytes顯示出當前空閒的物理內存總量。當這個數值變小時,Windows開始頻繁地調用磁盤頁面文件。若是這個數值很小,例如小於5 MB,系統會將大部分時間消耗在操做頁面文件上。 |
Memory |
% Committed Bytes in Use |
% Committed Bytes In Use 是 Memory: Committed Bytes 與Memory: Commit Limit之間的比值。(Committed memory指若是須要寫入磁盤時已在分頁文件中保留空間的處於使用中的物理內存。Commit Limit是由分頁文件的大小而決定的。若是擴大了分頁文件,該比例就會減少)。這個計數器只顯示當前百分比;而不是一個平均值。 |
Memory |
Page Faults/sec |
Page Faults/sec是指處理器處理錯誤頁的綜合速率。用錯誤頁數/秒來計算。當處理器請求一個不在其工做集(在物理內存中的空間)內的代碼或數據時出現的頁錯誤。這個計數器包括硬錯誤(那些須要磁盤訪問的)和軟錯誤(在物理內存的其它地方找到的錯誤頁)。許多處理器能夠在有大量軟錯誤的狀況下繼續操做。可是,硬錯誤能夠致使明顯的拖延。這個計數器顯示用上兩個實例中觀察到的值之間的差除以實例間隔的持續時間所得的值。 |
Network Interface |
Bytes Total/sec |
Bytes Total/sec是發送和接收字節的速率,包括幀字符在內。 |
Network Interface |
Packets/sec |
Packets/sec爲發送和接收數據包的速率。 |
Physical Disk |
% Busy Time |
% Busy Time指磁盤驅動器忙於爲讀或寫入請求提供服務所用的時間的百分比。 |
Physical Disk |
Avg. Disk Queue Length |
Avg. Disk Queue Length 指讀取和寫入請求(爲所選磁盤在實例間隔中列隊的)的平均數。 |
Physical Disk |
Current Disk Queue Length |
Current Disk Queue Length指在收集操做數據時在磁盤上未完成的請求的數目。它包括在快照內存時正在爲其提供服務中的請求。這是一個即時長度而非必定間隔時間的平均值。多主軸磁盤設備能夠一次有多個請求操做,可是其它同時發生的請求爲等候服務。這個計數器可能會反映一個暫時的高或低的列隊長度,可是若是在磁盤驅動器存在持續負載,可能值會老是很高。請求等待時間與這個列隊的長度減去磁盤上的主軸成正比。這個差值應小於2才能保持良好的性能。 |
Logical Disk |
% Free Space |
% Free Space 是所選定的邏輯磁盤驅動器上總的可用空閒空間的百分比。 |
Logical Disk |
Free Megabytes |
可用的 MB 顯示磁盤驅動器上還沒有分配的空間。 |
3、Perfmon功能之一——性能監視器
在Windows中,性能監視器以一個管理控制檯(MMC)單元的形式實現。在windows的開始->運行框中輸入perfmon.msc啓動Windows的性能監視器,能夠看到相似圖一的界面。性能監視器主要用來對指定的系統性能指標進行實時監控,但這些性能的指標記錄不能被保存。若是要保存這些性能日誌,能夠用後面介紹的「計數器日誌」功能。性能監視器的另一個功能是對計數器日誌生成的日誌記錄進行非實時的圖表化展示。在性能監視器中楞以經過「查看當前活動」或「當看日誌數據」功能項來指定監控的性能指標項目。通常說來,因爲性能監視器的顯示窗口大小有限,不宜指定太多的實時監控項目,不然窗口中的顯示很難突出須要重點監控的項目。咱們能夠根據不一樣的監控目標制訂不一樣的實時監控方案,每個方案都可以保存爲一個MSManagement Console(msc)文件。
4、Perfmon功能之二——計數器日誌
前面介紹了系統監視器的功能時提到,系統監視器主要用於重要性能指標的實時監控,它不能保存被監控的性能指標歷史數據。若是須要持續對系統的性能指標採樣,就必須用到Peofmon的計數器日誌的功能。計數器日誌在日誌文件中記錄指定的系統性能數據,這些日誌數據能夠用系統監視器查看或用其餘工具處理,這對於分析系統某一段時間內的運行情況或者是交由第三方性能管理工具來進行性能管理十分有用。
爲了說明如何使用計數器日誌,咱們要新建一個日誌會話。擴展控制檯中的「性能日誌和警報」節點下能夠看到「計數器日誌」分節點,右擊「計數器日誌」分節點,選擇「新建日誌設置」,指定日誌設置的名稱,點擊「肯定」,出現圖二的對話框,在這裏設定要在日誌中記錄的計數器(即須要記錄的性能指標)。點擊「添加對象」按鈕,將某個監視對象的全部計數器加入日誌記錄,或者點擊「添加計數器」按鈕加入單個計數器。日誌文件的默認保存路徑是C:\perflogs目錄,在設置時能夠根據須要在「日誌文件」項下修改。日誌文件保存的格式能夠根據須要設定成文本文件、二進制文件、SQL數據庫記錄。在「計劃」項下,能夠設置性能日誌的啓動和關閉時間計劃,也能夠設置日誌關閉後的指定動做。咱們能夠根據不一樣的監控需求制訂不一樣的性能日誌方案,每個方案都可以保存爲一個HTML文件。
5、Perfmon功能之三——跟蹤日誌
Perfmon的跟蹤日誌功能能夠提供對某些重要系統事件的跟蹤,也能夠指定對特定應用程序的跟蹤。跟蹤日誌以二進制文件保存(默認擴展名爲.etl),能夠用tracerpt對日誌進行分析,並生成CSV格式的dump文件。該功能目前沒有提供直觀的配置手段來訂製對特定應用程序的跟蹤,必須經過編輯系統的註冊表來實現。這一功能主要應用在程序調試、故障分析過程當中。圖三是訂製跟蹤日誌的對話框,在其「日誌文件」、「計劃」項下能夠設置日誌文件的存放路徑、文件大小限制、日誌啓停計劃等項目。
6、Perfmon功能之四——警報
Perfmon的警報功能是指當某個計數器的性能數據達到指定的值時,執行必定的動做,例如發送Email、用NetSend命令發送消息或者運行指定的程序。也能夠指定當警報發生時將警報看成系統的事件記錄在系統事件記錄裏,這樣能夠很方便地用事件查看器來調閱警報的內容。警報的報警指標設置與性能計數器的指標相同,針對不一樣的應用,咱們能夠制訂不一樣的警報策略。圖四示例的是當CPU的IdleTime低於70%時觸發一個警報的訂製對話框。在「操做」和|「計劃」項下,能夠配置警報發生時的指定操做、警報設置的啓停動做等。
7、Perfmon佈署方法
對Windows系統的性能監控須要有較高的用戶權限,Perfmon默認的可執行權限是管理員用戶,從系統安全性考慮,不建議將管理員做爲平常監控的用戶。Windows2000 Server提供了性能管理用戶組,在實施系統的性能監控時,可創建一個該組的普通用戶。
Windows提供了Perfmon的兩種佈署方式:本地監控和遠程監控。本地監控產生的日誌文件默認保存路徑是C:\perflogs目錄,在設置時能夠根據須要在「日誌文件」項下修改。本地監控產生的日誌文件除了能夠在本機用性能監視器進行觀測外,還能夠外傳到第三方監測分析平臺上。遠挰監控能夠實現對局域網內多臺監控目標進行集中採樣監控,其前提是監控主機與目標主機之間必須創建信任關係,而且打開相應的遠程訪問控制。在訪問控制比較嚴格的環境下,遠程監控難以佈署。佈署Permon時還應該考慮志文件的存放問題,若是要長時間收集性能數據,最好調整一下采樣間隔時間,若是採樣間隔時間設置得過小,日誌文件會快速增。
Perfmon的管理也有兩種方法:控制檯管理和命令行方式管理。能夠經過運行Perfmon.msc調出性能管理的控制檯,並根據監控策略制訂、管理控制檯。Perfmon的另外一種管理方式是命令行方式,Windows提供了一個專門用於管理性能監控的命令――Logman,它不只可以在命令行上啓動和中止日誌會話,並且可以從命令行建立新的日誌會話。有關Logman命令的用法可參閱Logman命令指南。
還有另一個命令能方便地採集到系統性能數據,但僅僅是獲取數據,並不產生警報和日誌記錄的動做。這種方式在使用第三方軟件來監控Windows系統的性能時常常用到。Windows提供了一個顯示當前性能指標的命令----Typeperf。用Typeperf能夠獲得前面提到的Perfmon的全部指標值。Typeperf的標準輸出是屏幕顯示,咱們能夠經過輸出重定義將結果輸出到文本文件當中,並將結果文件傳給第三方系統。這種應用方式下,Typeperf的動做由第三方軟件根據須要來管理,也能夠經過訂製計劃任務來定時啓動。有關Typeperf命令的用法可參閱Typeperf命令指南