Linux性能分析-top命令

Top命令详解

top命令能查看CPU,内存,IO, PID等信息。

先整体认识一下top命令的情况

 Linux性能分析-top命令_第1张图片


第一排:整体运行情况与uptime命令显示的是一样的

top :命令名称

10:13:25 :当前系统时间

54 days,1:53 :机器运行的时间,格式为天,时:分

2 users :当前登录用户数,是在线登录的用户数

load average:系统负载,定义为在特定时间间隔内运行队列中的平均进程数。 三个数值分别为  1分钟、5分钟、15分钟前到现在的平均值。 关于这三个值应该保持在一个什么样的状态,性能才比较好。对于单处理器单核(如果是多CUP多核,应该除以数量在比较),一般等于1.00,表示尽全力刚刚好,超过1.00表示已经负载了。所以一般希望维持在0.7比较合理。详细参考http://blog.scoutapp.com/articles/2009/07/31/understanding-load-averages

 

第二排:任务运行情况

Task:就是任务,就是进程的意思

total:进程总数

running:正在运行的进程数量

sleeping:睡眠的进程数量

stop:停止的进程数

注:stop与sleeping进程应区别,sleeping是主动放弃cpu,而stop是被动放弃cpu ,例单步跟踪,stop(暂停)的进程是无法自己回到运行状态的)

Zombie:僵尸进程数。In UNIX System terminology, a process that has terminated,but whose parent has not yet waited for it, is called a zombie。在UNIX 系统中,一个进程结束了,但是他的父进程没有等待(调用wait / waitpid)他, 那么他将变成一个僵尸进程。

注:找出具体僵尸进程的方法:ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 

 

第三排:CPU状态:

us:用户空间占用CPU百分比

sy:内核空间占用CPU百分比

ni:用户进程空间内改变过优先级的进程占用CPU

id:百分比空闲CPU百分比

wa:等待输入输出的CPU时间百分比

hi:硬中断(Hardware IRQ)占用CPU的百分比

si:软中断(Software Interrupts)占用CPU的百分比

st:(Steal time) 是服务的另一个虚拟处理器的时候,虚拟 CPU 等待实际 CPU 的时间的百分比。

 

第四排CPU状态:

total物理内存总量

used 使用的物理内存总量

free:空闲物理内存的大小

buffers:用于内存缓冲区的大小(写入的缓存)

 

第五排:交换区的状态

total — 交换区总量

used — 使用的交换区总量

free — 空闲交换区总量

cached — 缓冲的交换区总量(读出的缓存)

 

第四中使用的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四的free + 第四的buffers + 第五行的cached,按这个公式此台服务器的可用内存

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

接下来分别是各个进程的信息

PID — 进程id

USER — 进程所有者

PR — 进程优先级

NI — nice值。负值表示高优先级,正值表示低优先级

VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

SHR — 共享内存大小,单位kb

S — 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程

%CPU — 上次更新到现在的CPU时间占用百分比

%MEM — 进程使用的物理内存百分比

TIME+ — 进程使用的CPU时间总计,单位1/100秒

COMMAND — 进程名称(命令名/命令行)

 

PRI 和 NI 值,都会影响进程执行的优先级:Priority/PRI 由 OS 内核动态调整,用户不能调整(PRI 值越低,进程执行的优先级越高),Nice/NI 用户可以自己调整。相互关系:有个一般公式,PRI(new) = PRI(old) + NI。但是,PRI 是 OS 动态调整的,但是 PRI 的最终值还需要由 OS 分析决定的(虽然 NI 会影响 PRI)

 

其他使用技巧:

1.多U多核CPU监控

在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况:

 

2.高亮显示当前运行进程

敲击键盘“b”(打开/关闭加亮效果),top的视图变化如下我们发现进程id为2570的“top”进程被加亮了,top进程就是视图第二行显示的唯一的运行态(runing)的那个进程,可以通过敲击“y”键关闭或打开运行态进程的加亮效果。

 

3.进程字段排序

默认进入top时,各进程是按照CPU的占用量来排序的,在下图中进程ID为28894的java进程排在第一(cpu占用142%),进程ID为574的java进程排在第二(cpu占用16%)。

4. 通过”shift + >”或”shift + <”可以向右或左改变排序列

 

 

 

你可能感兴趣的:(Linux)