性能计数器

Processor/% Processor Time

 

阀值:处理器的阀值一般设为85%。

含义:这个计数器是处理器活动的主要指标。高数值并不一定是坏事,但是如果其他处理器相关的计数器(比如% Privileged Time 或者 Processor Queue Length线性增加的话,高CPU使用率就值得调查了。

 

Processor/% Privileged Time

阀值:如果数值持续大于75%就表示存在瓶颈。

含义:这个计数器表示一个线程在特权模式下所使用的时间比例。当你的程序调用操作系统的方法(比如文件操作,网络I/O或者分配内存),这些操作系统的方法是在特权模式下运行的。

Processor/% Interrupt Time

 

阀值:取决于处理器

含义:这个计数器表示处理器接收处理硬件中断所使用的时间比例。这个值间接指出产生中断的硬件设备活动,比如网络变化。这个计数器显著增加的话表示硬件可能存在问题。

System/Processor Queue Length

 

阀值:平均值持续大于2那么表示CPU存在瓶颈

 

含义:如果就绪的任务超过处理能力线程就会被放进队列。处理器队列是就绪但是未能被处理器执行的线程的集合,这是因为另外一个线程正在执行状态。持续或者反复发生2个以上的队列则明确的表示存在处理器瓶颈。你也能通过减少并发取得更大的吞吐量。

 

你可以结合Processor/% Processor Time来决定增加CPU的话你的程序是否能够受益。即使在多处理器的电脑上,对于CPU时间也是单队列。因此,在多处理器电脑上,Processor Queue Length (PQL)的值除以用来处理负载的CPU个数。

 

如果CPU非常忙(90%以上的使用率),PQL的平均值也持续大于2/CPU, 这是应该存在CPU瓶颈而且能够从更多的CPU中受益。或者,你可以减少线程的数量以及增加应用程序层的队列。这会引起少量的Context Switching,但是少许的Context Switching对于减少CPU负载是有好处的。PQL大于2但是CPU使用率却不高的的常见原因是对CPU时间的请求随机到达而且线程却从处理器申请到不对称的CPU时间。这意味着处理器并不是瓶颈,而你的线程逻辑是需要改进的。

System/Context Switches/sec

 

阀值:按照通常的规律,context switching速率小于5000/秒/CPU是不需要担心的。如果Context Switching速率达到15000/秒/CPU的话就是一个制约因素了。

含义:当一个高优先级的线程取代一个正在运行的低优先级线程,或者高优先级线程阻塞的时候就会发生Context Switching。大量的Context Switching可以发生在许多线程拥有相同的优先级的情况下,这通常表示有太多的线程竞争CPU,如果你没有看到太高的处理器使用率而且发现Context Switch非常低,那么表示线程被阻塞。


//////////Post script////////////

性能计数器解释

 

如果Process\Private Bytes计数器和Process\Working Set计数器的值持续升高
同时Memory\Availablebytes计数器的值却持续降低的话
说明很有可能是存在内存泄漏

 

windows 自带的Performance Monitor,控制面版->管理工具->性能
检测内存泄漏,我们一般可以监视Process对象的Handle CountVirutal Bytes Working Set三个CounterHandle Count记录了进程当前打开的HANDLE的个数,监视这个Counter有助于我们发现程序是否有Handle泄漏;Virtual Bytes记录了该进程当前在虚地址空间上使用的虚拟内存的大小,NT的内存分配采用了两步走的方法,首先,在虚地址空间上保留一段空间,这时操作系统并没有分配物理内存,只是保留了一段地址。然后,再提交这段空间,这时操作系统才会分配物理内存。所以,Virtual Bytes一般总大于程序的Working Set。监视Virutal Bytes可以帮助我们发现一些系统底层的问题; Working Set记录了操作系统为进程已提交的内存的总量,这个值和程序申请的内存总量存在密切的关系,如果程序存在内存的泄漏这个值会持续增加,但是Virtual Bytes却是跳跃式增加的。

 

性能对象

计数器

描述

Processor使用                                                                                                                                                                                                                                                                                                                           

%Processor Time(所有实例)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              

指处理器执行非闲置线程时间的百分比。这个计数器设计成用来作为处理器活动的主要指示器。它通过在每个范例间隔中衡 量处理器用于执行闲置处理线程的时间,并且用 100% 减去该值得出。(每 台处理器有一个闲置线程,该线程在没有其它线程可以运行时消耗周 期)。可将其视为范例间隔用于做有用工作的百分比。这个计数器显 示在范例间隔时所看到的忙时平均值。这个值是用 100% 减去该服务不活 动的时间计算出来的。

Proccesor瓶颈                                                                                                                                                                                                  

Interrupts/sec

指处理器每秒钟接收并维护的硬件中断的平均值。它不包括 DPC,DPC 将单独计算。这个值是产生中断的设备(如:系统时钟、鼠标、磁盘驱动器、数据交流线路、网络街面卡和其它附件设备)的活动的间接指示器,这些设备通常在完成了一项任务或需要注意时中断处理器。正常的线程操作在中断时悬停。大多数的系统时钟每隔 10 毫秒中断处理器一次,形成了间隔活动的后台。这个计数值显示用上两个实例中观察到的值之间的差除于实例间隔的持续时间所得的值。

System/Processor Queue Length(所有实例)

是指处理列队中的线程数。即使在有多个处理器 的计算机上处理器时间也会有一个单列队。不象磁盘计数器,这个计数器仅 计数就绪的线程,而不计数运行中的线程。如果处理器列队中总是有两个以上的线程 通常表示处理器堵塞。这个计数器仅显示上一次观察的值;而不是一个平 均值。

System/Context Switches/sec

指计算机上的所有处理器全都从一个线程转换到另一个线程的综合速率。当正在运行的线程自动放弃处理器时出现上下文转换,由一个有更高优先就绪的线程占先或在用户模式和特权(内核)模式之间转换以使用执行或分系统服务。它是在计算机上的所有处理器上运行的所有线程的Thread: Context Switches/sec 的总数并且用转换数量衡量。在系统和线程对象上有上下文转换计数器。这个计数值显示在上一次两个实例中观察到的值除于实例间隔的持续时间所得的值的差异。

Process

(进程)

Private Bytes

指这个处理不能与其它处理共享的、已分配的当前 字节数。

Virtual Bytes

指处理使用的虚拟地址空间的以字节数显示的当前大小。 使用虚拟地址空间不一定是指对磁盘或主内存页的相应的使用。虚 拟空间是有限,如果使用过多,可能会限制处理加载数据 库的能力。

Working Set

指这个处理的 Working Set 中的当前字节数。 Working Set 是在处理中被线程最近触到的那个内存页集。如果 计算机上的可用内存处于阈值以上,即使页不在使用中,也会留在一 个处理的 Working Set中。当可用内存降到阈值以下,将从 Working Set 中删除页。如果需要页时,它会在离开主内存前软故障返回    到 Working Set 中。

Handle Count

由这个处理现在打开的句柄总数。这个数字是在这个处理中每个线程当前打开的句柄的总数。

Objects

Threads

线程指在数据收集时在计算机中线程的数目。请注意这是 一个即时计算而不是一个时间间隔的平均值。一个线程为一个基本 的可执行实体,该实体在处理器中执行指令。

Memory使用

Available Bytes

是计算机上可用于运行处理的有效物理内存的字节数量。是用零、 空闲和备用内存表上的空间总值计算的。空闲内存指可以使用内存;零内存指为了防 止以后的处理看到以前处理使用的数据而在很多页内存中充满了零的内存。备用内 存是指从处理的工作集(它的物理内存)移到磁盘的,但是仍旧可以调用的内存。这个计数器只显示上一次观察到的值;它不是一个平均值。

Cache Bytes

是 System Cache Resident Bytes 的总数。System Driver Resident Bytes、System Code Resident Bytes、以及 Pool Paged Resident Bytes 计数器。该计数器只显示最后一次观察的值,它不是一个平均值。

Memory瓶颈或溢出

Pages/sec

是指为解析硬页错误从磁盘读取或写入磁盘的页数。(当处理程序请求 不在本身工作集或物理内存其它地方中的代码或数据,而必须要从磁盘上检索时就会出现硬页错误)。这个计数器设计成可以显示导致系统范围延缓类型错误的主要指示器。它是 Memory: Pages Input/sec 和 Memory: Pages Output/sec 的 总和。是用页数计算的,以便在不用做转换的情况下就可以同其它页计数如:  Memory: Page Faults/sec 做比较,这个值包括为满足错误而在文件系统缓存(通常由应用程 序请求)的非缓存映射内存文件中检索的页。这个计数器显示用上两个实例中观察到的值 之间的差除于实例间隔的持续时间所得的值。

Page Reads/sec

是指为解析硬页错误而读取磁盘的次数。(当处理请求的硬 页错误不在工作集和物理内存其它地方中的代码或数据,而必须从磁盘上检索时 就会出现硬页错误)。这个计数器设计成可以显示导致系统范围延缓 错误的主要指示器。这个包括要满足错误而在文件系统缓存(通常由应用程 序请求)的非缓存映射内存文件终检索的页。这个计数器显示用上两个实例中 观察到的值之间的差除于实例间隔的持续时间所得的值。

Transition Faults/sec

是指由在修改页列表、备份页表或在页错误时写入 磁盘上造成的页错误数量。这些页是在没有额外磁盘活动的情况下恢复的。传输 错误是在不计算每次操作时出错的页数的情况下计算错误数量。这个计数 器显示用上两个实例中观察到的值之间的差除于实例间隔的持续时间所得的值。

Pool Paged Bytes

指在分页池中的字节数,分页池是系统内存(操作系 统使用的物理内存)中可供对象(在不处于使用时可以写入磁盘的)使 用的一个区域。Memory: Pool Paged Bytes 的计数方式与 Process: Pool Paged Bytes 的方式不同,因此可能不等于 Process: Pool Paged Bytes: _Total 。这个 计数器仅显示上一次观察的值;而不是一个平均值。

Pool Nonpaged Bytes

指在非分页池中的字节数,非分页池是指系统内存(操作系统使用的物理内存)中可供对象(指那些在不处于使用时不可以写入磁盘上 而且只要分派过就必须保留在物理内存中的对象)使用的一个区域。Memory: Pool Nonpaged Bytes 的计数方式与 Process: Pool Nonpaged Bytes 的计数方式 不同,因此可能不等于Pool Nonpaged Bytes: _Total。 这个计数器仅显示上一次观察的值;而不是一个平均值。

PhysicalDisk

的使用

%Disk Time

指所选磁盘驱动器忙于为读或写入请求提供服务所用的时间 的百分比。

请谨慎对待 % Disk Time 计数器。因为该计数器的 _Total 实例不能精确反映多磁盘系统的利用率,因此使用 % Idle Time 计数器也非常重要。

% Idle Time

汇报在实例间隔时磁盘闲置时间的百分比。

Disk Reads/sec

指在此盘上读取操作的速率。

Disk Writes/sec

指在此盘上写入操作的速率。

PhysicalDisk的瓶颈

Avg.Disk Queue Length(所有实例)

指读取和写入请求(为所选磁盘在实例间隔中列队的)的平均数。

System

File Data Operations/ sec

指在计算机的所有逻辑磁盘上读取和写入操作的综合速度。这是系统的逆转率:每秒钟的文件控制操作。这个总值显示了上两个实例中观察到的值的差异除于实例间隔的时间。

Processor Queue Length

是指处理列队中的线程数。即使在有多个处理器 的计算机上处理器时间也会有一个单列队。不象磁盘计数器,这个计数器仅 计数就绪的线程,而不计数运行中的线程。如果处理器列队中总是有两个以上的线程 通常表示处理器堵塞。这个计数器仅显示上一次观察的值;而不是一个平 均值。

网络使用

Network Segment\ % Net Utilization
请注意,必须为“网络监视器”安装“网络监视器”驱动程序才能使用该计数器。

 

网络吞吐量

 

协议传输计数器(随网络协议而改变);对于 TCP/IP:Network Interface\ Bytes total/sec
Network Interface\ Packets/sec
Server\ Bytes Total/sec or Server\ Bytes Transmitted/sec 和 Server\ Bytes Received/sec
可能需要监视网络的其他对象或服务器吞吐量,如监视网络活动中所述。

Cache

 

 

Paging File

 

 

Server

 

 

Thread

 

 

 



你可能感兴趣的:(性能指标,软件性能)