现任职北京某互联网公司运维经理,高级架构师,涉足互联网运维行业已经超过10年。曾服务于京东商城,互动百科等互联网公司,早期运维界新星。 长期专研,C语言开发,操作系统内核,大型互联网架构。http://www.bdkyr.com
全部博文(166)
分类: LINUX
2013-10-14 11:06:08
功能:
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。显示系统当前的进程和其他状况; top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止. 比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.
语法:
top [-] [d delay] [q] [c] [s] [S] [i]
参数:
-d N 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
-q 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
-S 指定累计模式, 禁用一些效互指令;
-s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
-i 使top不显示任何闲置或者僵死进程。
-c 显示整个命令行而不只是显示命令名
举例详细说明:
top - 16:23:47 up 6:40, 1 user, load average: 0.06, 0.60, 0.48
Tasks: 98 total, 2 running, 96 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.7%us, 0.0%sy, 0.0%ni, 99.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.3%st
Mem: 320512k total, 313224k used, 7288k free, 75824k buffers
Swap: 787176k total, 0k used, 787176k free, 88780k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
3966 root 15 0 90936 3372 2620 R 0.3 1.1 0:00.63 sshd
6323 root 15 0 12756 1064 812 R 0.3 0.3 0:00.06 top
1 root 15 0 10368 704 592 S 0.0 0.2 0:02.16 init
2 root RT -5 0 0 0 S 0.0 0.0 0:00.00 migration/0
3 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0
4 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/0
5 root 10 -5 0 0 0 S 0.0 0.0 0:03.02 events/0
6 root 10 -5 0 0 0 S 0.0 0.0 0:00.01 khelper
7 root 10 -5 0 0 0 S 0.0 0.0 0:00.01 kthread
9 root 10 -5 0 0 0 S 0.0 0.0 0:00.00 xenwatch
10 root 10 -5 0 0 0 S 0.0 0.0 0:00.00 xenbus统计信息区
前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime 命令的执行结果。其内容如下:
16:23:47 #当前时间
up 6:40 #系统运行时间,格式为时:分
1 user #当前登录用户数
load average: 0.06, 0.60, 0.48 #系统负载,即任务队列的平均长度。
[root@vpn etc]# uptime
16:25:02 up 6:41, 1 user, load average: 0.06, 0.60, 0.48
三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。
第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行,例如:
Tasks: 210 total, 1 running, 209 sleeping, 0 stopped, 0 zombie
Cpu0 : 15.4%us, 0.0%sy, 0.0%ni, 84.5%id, 0.1%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu1 : 18.4%us, 0.0%sy, 0.0%ni, 81.4%id, 0.2%wa, 0.0%hi, 0.0%si, 0.0%st #多个CPU
Cpu2 : 14.1%us, 0.0%sy, 0.0%ni, 85.8%id, 0.1%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu3 : 14.1%us, 0.0%sy, 0.0%ni, 85.3%id, 0.5%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu4 : 14.2%us, 0.1%sy, 0.0%ni, 85.5%id, 0.2%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu5 : 11.1%us, 0.0%sy, 0.0%ni, 88.7%id, 0.2%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu6 : 2.5%us, 0.0%sy, 0.0%ni, 97.2%id, 0.2%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu7 : 1.9%us, 0.6%sy, 0.0%ni, 95.6%id, 1.3%wa, 0.1%hi, 0.6%si, 0.0%st
Mem: 8175372k total, 8118552k used, 56820k free, 96532k buffers
Swap: 8385920k total, 179544k used, 8206376k free, 5770436k cached
当有多个CPU时,按键盘上的1键可以查看。
说明:
Tasks: 29 total #进程总数
1 running #正在运行的进程数
28 sleeping #睡眠的进程数
0 stopped #停止的进程数
0 zombie #僵尸进程数
Cpu(s): 0.3% us #用户空间占用CPU百分比
1.0% sy #内核空间占用CPU百分比
0.0% ni #用户进程空间内改变过优先级的进程占用CPU百分比
98.7% id #空闲CPU百分比
0.0% wa #等待输入输出的CPU时间百分比
0.0% hi #硬件中断
0.0% si # si: 将内存从磁盘交换回物理 RAM 的速率(以 KB/秒为单位)
so:反之。
最后两行为内存信息。内容如下:
Mem: 191272k total #物理内存总量
173656k used #使用的物理内存总量
17616k free #空闲内存总量
22052k buffers #用作内核缓存的内存量
Swap: 192772k total #交换区总量
0k used #使用的交换区总量
192772k free #空闲交换区总量
123988k cached #缓冲的交换区总量
内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
该数值即为这些内容已存在于内存中的交换区的大小。
相应的内存再次被换出时可不必再对交换区写入。
进程信息区
统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。
序号 列名 含义
a PID 进程id
b PPID 父进程id
c RUSER Real user name
d UID 进程所有者的用户id
e USER 进程所有者的用户名
f GROUP 进程所有者的组名
g TTY 启动进程的终端名。不是从终端启动的进程则显示为 ?
h PR 优先级
i NI nice值。负值表示高优先级,正值表示低优先级
j P 最后使用的CPU,仅在多CPU环境下有意义
k %CPU 上次更新到现在的CPU时间占用百分比
l TIME 进程使用的CPU时间总计,单位秒
m TIME+ 进程使用的CPU时间总计,单位1/100秒
n %MEM 进程使用的物理内存百分比
o VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
p SWAP 进程使用的虚拟内存中,被换出的大小,单位kb。
q RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
r CODE 可执行代码占用的物理内存大小,单位kb
s DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
t SHR 共享内存大小,单位kb
u nFLT 页面错误次数
v nDRT 最后一次写入到现在,被修改过的页面数。
w S 进程状态。
D=不可中断的睡眠状态
R=运行
S=睡眠
T=跟踪/停止
Z=僵尸进程
x COMMAND 命令名/命令行
y WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
z Flags 任务标志,参考 sched.h
默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通过下面的快捷键来更改显示内容。
更改显示内容
通过 f 键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z 即可显示或隐藏对应的列,最后按回车键确定。如下:
按 o 键可以改变列的显示顺序。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z 可以将相应的列向左移动。最后按回车键确定。
按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的 R 键可以将当前的排序倒转。
其他
下面介绍在top命令执行过程中可以使用的一些交互命令。从使用角度来看,熟练的掌握这些命令比掌握选项还重要一些。这些命令都是单字母的,如果在命令行选项中使用了s选项,则可能其中一些命令会被屏蔽掉。
Ctrl+L 擦除并且重写屏幕。
h或者? 显示帮助画面,给出一些简短的命令总结说明。
H 查看具体的执行线程
k 终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。
i 忽略闲置和僵死进程。这是一个开关式命令。
q 退出程序。
r 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。
S 切换到累计模式。
s 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。
f或者F 从当前显示中添加或者删除项目。
o或者O 改变显示项目的顺序。
l 切换显示平均负载和启动时间信息。
m 切换显示内存信息。
t 切换显示进程和CPU状态信息。
c 切换显示命令名称和完整命令行。
M 根据驻留内存大小进行排序。
P 根据CPU使用百分比大小进行排序。
T 根据时间/累计时间进行排序。
W 将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。
按u键,然后输入显示的用户,
实例说明:
Last login: Thu Apr 7 21:25:16 2011 from 192.168.15.254
[xuekun@lamp-001 ~]$ top # 然后从键盘上敲入字母c, 切换显示命令名称和完整命令行。
top - 17:15:36 up 106 days, 22:34, 1 user, load average: 1.70, 1.63, 1.57
Tasks: 186 total, 1 running, 185 sleeping, 0 stopped, 0 zombie
Cpu(s): 15.7%us, 0.5%sy, 0.0%ni, 83.2%id, 0.3%wa, 0.0%hi, 0.3%si, 0.0%st
Mem: 16301168k total, 16186840k used, 114328k free, 396704k buffers
Swap: 16386292k total, 495176k used, 15891116k free, 2646800k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
2773 daemon 18 0 2538m 604m 1452 S 99 3.8 22882:13 httpd #没有按下字母c
13379 wikdoc 21 0 2320m 1.4g 10m S 15 8.9 527:24.65 java
32191 root 25 0 1587m 937m 10m S 4 5.9 149:34.91 java
32090 root 25 0 1636m 998m 10m S 3 6.3 142:57.31 java
32402 root 25 0 1548m 854m 10m S 2 5.4 169:12.17 java
29420 daemon 18 0 2804m 1.0g 1464 S 2 6.6 441:42.16 httpd
18938 daemon 18 0 2882m 1.0g 1460 S 1 6.6 459:37.93 httpd
32306 root 25 0 1554m 889m 10m S 1 5.6 128:23.02 java
15352 wikart 23 0 1714m 700m 10m S 1 4.4 833:39.70 java
15417 wikart 18 0 1811m 143m 1376 S 1 0.9 115:27.25 httpd
15424 wikart 18 0 1819m 144m 1380 S 0 0.9 128:02.25 httpd
[xuekun@lamp-001 ~]$top #按下字母c,注意观察绿色标注部分,显示了命令的完整路径。
top - 17:20:58 up 106 days, 22:40, 1 user, load average: 1.86, 1.65, 1.57
Tasks: 184 total, 1 running, 183 sleeping, 0 stopped, 0 zombie
Cpu(s): 17.6%us, 0.7%sy, 0.0%ni, 80.8%id, 0.7%wa, 0.0%hi, 0.3%si, 0.0%st
Mem: 16301168k total, 16188968k used, 112200k free, 396220k buffers
Swap: 16386292k total, 495176k used, 15891116k free, 2650624k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
2773 daemon 18 0 2538m 604m 1452 S 100 3.8 22887:33 /application/apache2.2.13/bin/httpd -k start
13379 wikdoc 21 0 2320m 1.4g 10m S 24 8.9 528:12.17 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
32402 root 25 0 1548m 854m 10m S 8 5.4 169:33.44 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
32090 root 25 0 1636m 998m 10m S 5 6.3 143:12.73 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
32191 root 25 0 1587m 937m 10m S 5 5.9 149:51.05 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
18938 daemon 18 0 2882m 1.0g 1460 S 2 6.6 459:42.26 /application/apache2.2.13/bin/httpd -k start
32306 root 25 0 1554m 889m 10m S 2 5.6 128:37.48 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
29420 daemon 18 0 2804m 1.0g 1464 S 2 6.6 441:46.43 /application/apache2.2.13/bin/httpd -k start
15352 wikart 23 0 1714m 700m 10m S 1 4.4 833:43.93 /application/jdk1.6.0_10/bin/java -Djava.util.logging.manage
说明:
[root@llff ~]# top # 敲入字幕i 忽略闲置和僵死进程。这是一个开关式命令。
Tasks: 88 total, 1 running, 87 sleeping, 0 stopped, 0 zombie
Cpu(s): 27.9%us, 6.6%sy, 0.0%ni, 64.5%id, 0.0%wa, 0.0%hi, 0.7%si, 0.3%st
Mem: 2097152k total, 2037768k used, 59384k free, 24408k buffers
Swap: 4192956k total, 574336k used, 3618620k free, 278824k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
6462 xuekun 15 0 12736 1060 804 R 0.0 0.1 0:00.02 top
[root@linna~]# top #按u键,然后输入显示的用户,查看这个用户运行的进程情况
top - 23:36:02 up 12 min, 1 user, load average: 0.00, 0.06, 0.05
Tasks: 76 total, 1 running, 75 sleeping, 0 stopped, 0 zombie
Cpu(s): 1.3%us, 2.0%sy, 0.0%ni, 94.2%id, 2.0%wa, 0.1%hi, 0.4%si, 0.0%st
Mem: 255412k total, 115576k used, 139836k free, 24516k buffers
Swap: 3148732k total, 0k used, 3148732k free, 54632k cached
Which user (blank for all): 这里输入
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
3010 root 15 0 2292 896 704 R 1.4 0.4 0:00.01 top
1 root 18 0 2160 640 556 S 0.0 0.3 0:01.59 init