Linux命令工具 top详解

Posted fukan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux命令工具 top详解相关的知识,希望对你有一定的参考价值。

Linux命令工具 top详解

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定。 
常在linux系统下玩,这是必须掌握的命令之一; 
下面详细说说这个命令:

敲入top进入:

top - 09:14:56 up 264 days, 20:56,  1 user,  load average: 0.02, 0.04, 0.00
Tasks:  87 total,   1 running,  86 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.0%us,  0.2%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.2%st
Mem:    377672k total,   322332k used,    55340k free,    32592k buffers
Swap:   397308k total,    67192k used,   330116k free,    71900k cached
  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                        
    1 root      20   0  2856  656  388 S  0.0  0.2   0:49.40 init                                            
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd                                        
    3 root      20   0     0    0    0 S  0.0  0.0   7:15.20 ksoftirqd/0                                     
    4 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0

第一行

09:14:56 : 系统当前时间 
264 days, 20:56 : 系统开机到现在经过了多少时间 
2 users : 当前2用户在线 
load average: 0.02, 0.04, 0.00: 系统1分钟、5分钟、15分钟的CPU负载信息

load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

第二行

Tasks:任务; 
87 total:很好理解,就是当前有87个任务,也就是87个进程。 
1 running:1个进程正在运行 
86 sleeping:86个进程睡眠 
0 stopped:停止的进程数 
0 zombie:僵死的进程数

第三行

Cpu(s):表示这一行显示CPU总体信息 
0.0%us:用户态进程占用CPU时间百分比,不包含renice值为负的任务占用的CPU的时间。 
0.7%sy:内核占用CPU时间百分比 
0.0%ni:改变过优先级的进程占用CPU的百分比 
99.3%id:空闲CPU时间百分比 
0.0%wa:等待I/O的CPU时间百分比 
0.0%hi:CPU硬中断时间百分比 
0.0%si:CPU软中断时间百分比 
注:这里显示数据是所有cpu的平均值,如果想看每一个cpu的处理情况,按1即可;折叠,再次按1;

第四行

Men:内存的意思 
8175320kk total:物理内存总量 
8058868k used:使用的物理内存量 
116452k free:空闲的物理内存量 
283084k buffers:用作内核缓存的物理内存量

第五行

Swap:交换空间 
6881272k total:交换区总量 
4010444k used:使用的交换区量 
2870828k free:空闲的交换区量 
4336992k cached:缓冲交换区总量

 

备注:

第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存:18537836k +169884k +3612636k = 22GB左右。

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

进程信息

再下面就是进程信息: 
PID:进程的ID 
USER:进程所有者 
PR:进程的优先级别,越小越优先被执行 
NI:nice值。负值表示高优先级,正值表示低优先级 
VIRT:进程占用的虚拟内存总量,单位kb。VIRT=SWAP+RES
RES:进程占用的物理内存 (进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA)
SHR:进程使用的共享内存 
S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数 
%CPU:进程占用CPU的使用率 
%MEM:进程使用的物理内存和总内存的百分比 
TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。单位1/100秒 
COMMAND:进程启动命令名称

top命令交互操作指令

下面列出一些常用的 top命令操作指令

q:退出top命令
<Space>:立即刷新
s:设置刷新时间间隔
c:显示命令完全模式
t::显示或隐藏进程和CPU状态信息
m:显示或隐藏内存状态信息
l:显示或隐藏uptime信息
f:增加或减少进程显示标志
S:累计模式,会把已完成或退出的子进程占用的CPU时间累计到父进程的MITE+
P:按%CPU使用率排行
T:按MITE+排行
M:按%MEM排行
u:指定显示用户进程
r:修改进程renice
kkill:进程
i:只显示正在运行的进程
W:保存对top的设置到文件~/.toprc,下次启动将自动调用toprc文件的设置。
h:帮助命令。
q:退出

注:强调一下,使用频率最高的是P、T、M,因为通常使用top,我们就想看看是哪些进程最耗cpu资源、占用的内存最多; 
注:通过”shift + >”或”shift + <”可以向右或左改变排序列 
如果只需要查看内存:可用free命令。只查看uptime信息(第一行),可用uptime命令

高亮显示当前运行进程:敲击键盘“b”(打开/关闭加亮效果)

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

 

参考:

http://www.cnblogs.com/me115/p/3842081.html

http://www.cnblogs.com/peida/archive/2012/12/24/2831353.html

以上是关于Linux命令工具 top详解的主要内容,如果未能解决你的问题,请参考以下文章

linux top命令详解

一文详解 Linux 系统常用监控工具(top,htop,iotop,iftop)

Linux系统下常用性能分析工具top命令,怎么详解?

linux top命令详解

linux top命令详解

linux的top命令参数详解