博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】Windows性能监控工具Perfmon的使用、性能指标分析
阅读量:5884 次
发布时间:2019-06-19

本文共 2926 字,大约阅读时间需要 9 分钟。

目录结构

一、Perfmon简介、性能监控指标、性能对象指标    1.常用的性能监控指标    2.常用的性能对象与指标二、Perfmon的启用和监控设置三、性能分析方法    1.内存分析方法    2.处理器分析法    3.磁盘I/O分析方法

 

一、Perfmon简介、性能监控指标、性能对象指标

Perfmon:提供了图表化的系统性能实时监视器、性能日志和警报管理,可用于监视CPU使用率、内存使用率、硬盘读写速度、网络速度等,可以很方便地使用第三方工具进行性能分析。

1.常用的性能监控指标

Perfmon性能监控对象总共有上百个性能指标,我们关注一个系统的性能时,不可能关注这么多指标,有些性能指标对实际的应用系统影响并不大。但对一个Windows操作系统来说,CPU、内存(Memory)、磁盘(Disk)、网络(Network)等关键对象是性能监控中必不可少的项。

2.常用的性能对象与指标

性能对象 计数器 提供的信息
Processor % ldle Time 处理器在采样期间空闲时间的百分比
Processor % Processor Time 指处理器用来执行非闲置线程时间的百分比。
(CPU占用率)
Processor % User Time 处理器处于用户模式的时间百分比
Memory Available Bytes 显示出当前空闲的物理内存总量。
该数值↓,说明Windows开始频繁地调用磁盘页面文件;该数值<5MB时,系统会将Available Memory Bytes的大部分时间消耗在操作页面文件上
Memory % Committed Bytes In Use 内存使用百分比,[Compitted Bytes / Commit Limit]的比值
Memory Page Faults/sec 指处理器处理错误页的综合速率,[错误页数/s]来计算
Network Interface Bytes Total/sec 发送和接收字节的速率,包括帧字符在内
Network Interface Packets/sec 发送和接收数据包的速率
Physical Disk % Busy Time 磁盘驱动器忙于为读or写入请求提供服务所用时间的百分比。
若该数值比较大,则硬盘有可能是瓶颈
Physical Disk Avg. Disk Queue Length 磁盘队列的平均长度。磁盘完成对读取和写入请求的处理时间,磁盘数据吞吐量的外在表现
Physical Disk Current Disk Queue Length 在收集操作数据时,磁盘上未完成的请求数目

以上的4个指标比较关键:

% Processor Time
% Committed Bytes In Use
Bytes Total/sec
% Busy Time

 

二、Perfmon的启用和监控设置

Perfmon 使用方法:

1.开始输入perfmon后回车,即可打开perfmon.exe

 
 

2.在perfmon.exe的左窗格中,单击【系统监视器】

 
 

3.在右窗格中单击右键,然后单击【添加计数器】

 
 

or 点击监控图上方的【+】也可以打开添加计数器的窗口

 
 

4.在“性能对象”列表中,选择所需的性能指标计数器类别,以在Perfmon.exe中显示对应指标的监控图形,然后单击【添加】-->【确认】

 
 
 
 

在计数器勾选区域:

选中监控图底部的某个计数器,右键【属性】,可编辑该计数器的线条颜色、宽度等样式

 
 

通过切换点击不同的计数器类别,可实时观察到所统计的【最新值、平均值、最小值、最大值、持续时间】

 
 

在监控图区域:

右键【属性】,可设置采样的持续时间(默认100s)、每间隔多少时间采样一次
右键【图形另存为】,可将本地性能监控的采样图保存到本地
右键【清除】,可将当前监控上的采样图清除,而后从左至右继续开始新的采样图

 
 
 
暂停采样/继续采样

 

三、性能分析方法

1.内存分析方法

内存分析:用于判断系统有无内存瓶颈,是否需要通过增加内存等手段提高系统性能表现

内存分析的主要方法和步骤:

(1)首先查看Memory:% Commitued Bytes in Use指标
如果该指标数值比较大,系统可能出现了内存方面的问题,需要继续下面步骤进一步分析。
另外也可以查看Available Bytes,如果该值小,则说明可用内存不足,存在性能瓶颈。
(2)注意Pages/secPages Read/secPage Faults/sec的值
操作系统会利用磁盘较好的方式提高系统可用内存量or提高内存的使用效率,这三个指标直接反应了操作系统进行磁盘交换的频度。
Pages/sec值持续高于几百,可能有内存问题;Pages/sec值不一定大就表明有内存问题,可能是运行使用内存映射文件的程序所致。
Page Faults/sec说明每秒发生页面失效次数,页面失效次数越多,说明操作系统向内存读取的次数越多。此时需要查看Pages Read/sec的计数值,该计数器的阀值为5,如果计数值>5,则可以判断存在内存方面的问题。

2.处理器分析法

(1)首先看System:% Total Processor Time性能计数器的计数值

该计数器的数值体现服务器整体处理器的利用率,对多处理器的系统而言,该计数器体现的是所有CPU的平均利用率。如果该值持续超过90%,则说明整个系统面临着处理器方面的瓶颈,需要通过增加处理器来提高性能。
(2)其次查看每个CPU的% User Time
%User Time是系统的非核心操作消耗的CPU时间,如果该值较大,可以考虑是否能通过友好算法等方法降低这个值。如果该服务器是数据库服务器,%User Time值大的原因很可能是数据库的排序或是函数操作消耗了过多的CPU时间,此时可以考虑对数据库系统进行优化。
(3)研究系统处理器瓶颈:查看System:Processor Queue Length计数器的值
当该计数器的值 > (CPU数量的总数+1)时,说明产生了处理器阻塞。在处理器的% Process Time很高时,一般都随处理器阻塞,但产生处理器阻塞时,Processor:%Process Time 计数器的值并不一定很大,此时就必须查找处理器阻塞的原因。

3.磁盘I/O分析方法

(1)计算每磁盘的IO数

每磁盘的I/O数可用来与磁盘的I/O能力进行对比,如果经过计算得到的每磁盘I/O数超过了磁盘标称的I/O能力,则说明确实存在磁盘的性能瓶颈。

4.网络分析方法

(1)Network Interface:Bytes Total/sec

Bytes Total/sec为发送和接收字节的速率,可以通过该计数器值来判断网络链接速度是否是瓶颈,具体操作方法是用该计数器的值和目前网络的带宽进行比较。

转自:https://www.jianshu.com/p/f82c2b726ecf

转载于:https://www.cnblogs.com/rookie-byebye/p/10375435.html

你可能感兴趣的文章
python random
查看>>
AfxMessageBox和MessageBox区别
查看>>
通过Typings为Visual Studio Code增强智能提示功能
查看>>
5天不再惧怕多线程——第二天 锁机制
查看>>
互联网推送服务原理:长连接+心跳机制(MQTT协议)
查看>>
Android 系统ID介绍
查看>>
Know How And When To Use System.Message_Level To Control Messages In Oracle Forms
查看>>
Atitit 验证 数字验证 非空验证的最佳算法 h5
查看>>
ASP.NET Core 发布
查看>>
cocos2d-x-lua基础系列教程五(lua单例)
查看>>
升级_开阔视野之Oracle图形化升级(dbca建库后升级)—10.2.0.1.0升为10.2.0.5.0
查看>>
深入浅出 - Android系统移植与平台开发(七)- 初识HAL【转】
查看>>
初探linux子系统集之timer子系统(三)
查看>>
利用VisualVM监视远程JVM
查看>>
TortoiseGit学习系列之TortoiseGit基本操作将提交到本地的项目推送到在线仓库(图文详解)...
查看>>
关于spring mybateis 定义resultType="java.util.HashMap"
查看>>
『TensorFlow』读书笔记_Inception_V3_上
查看>>
python爬虫从入门到放弃(四)之 Requests库的基本使用(转)
查看>>
程序员怎么留住健康?
查看>>
【ANT】ant使用
查看>>