【操作系统之八】Linux常用命令之top
一、概念
Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,且可以通过交互式命令自定义显示内容,类似于Windows的任务管理器.
二、命令格式
[root@PCS101 logs]# top top - 21:48:39 up 8:57, 2 users, load average: 0.36, 0.24, 0.14 Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie %Cpu(s): 5.0 us, 1.7 sy, 0.0 ni, 93.0 id, 0.0 wa, 0.3 hi, 0.0 si, 0.0 st KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers KiB Swap: 1046524 total, 280708 used, 765816 free. 365556 cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 8096 root 20 0 320624 38508 21192 S 1.7 3.8 0:41.03 Xorg 13536 tabalt 20 0 697336 104272 56776 S 1.7 10.3 0:08.29 gnome-langu+ 9426 tabalt 20 0 1213228 72976 16860 S 1.0 7.2 2:07.27 compiz 197 root 20 0 0 0 0 S 0.3 0.0 0:36.13 kworker/0:2 1009 root 20 0 303112 3392 1500 S 0.3 0.3 0:00.93 polkitd 9670 tabalt 20 0 325932 4300 2256 S 0.3 0.4 0:40.27 vmtoolsd 14016 root 25 5 43940 2408 2000 S 0.3 0.2 0:01.12 http 14149 tabalt 20 0 591180 19504 12820 S 0.3 1.9 0:00.45 gnome-termi+ 1 root 20 0 33648 1972 744 S 0.0 0.2 0:01.79 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 0:02.80 ksoftirqd/0 4 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0 5 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0H 7 root 20 0 0 0 0 S 0.0 0.0 0:05.55 rcu_sched 8 root 20 0 0 0 0 R 0.0 0.0 0:03.43 rcuos/0 9 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/1 10 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/2
1、系统信息统计
前五行是系统整体状态的统计信息展示区域。
(1)第一行显示服务器概况
如下所示,第一行列出了服务器运行了多长时间,当前有多少个用户登录,服务器的负荷情况等,使用uptime命令能获得同样的结果。
top - 21:48:39 up 8:57, 2 users, load average: 0.36, 0.24, 0.14 / / / \ 系统时间 运行时长 当前登录用户数 平均负载(1分钟、5分钟、15分钟)
平均负载的值越小代表系统压力越小,越大则代表系统压力越大。通常,我们会以最后一个数值,也就是15分钟内的平均负载作为参考来评估系统的负载情况。
对于只有单核cpu的系统,1.0是该系统所能承受负荷的边界值,大于1.0则有处理需要等待。
一个单核cpu的系统,平均负载的合适值是0.7以下。如果负载长期徘徊在1.0,则需要考虑马上处理了。超过1.0的负载,可能会带来非常严重的后果。
当然,多核cpu的系统是在前述值的基础上乘以cpu内核的个数。如对于多核cpu的系统,有N个核则所能承受的边界值为N.0。
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
可以使用如下命令来查看每个处理器的信息:
cat /proc/cpuinfo
如果只想计算有多少个cpu内核,可以使用如下命令:
cat /proc/cpuinfo | grep 'model name' | wc -l
(2)第二行是进程信息:
Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie / / / / / 进程总数 正运行进程数 睡眠进程数 停止进程数 僵尸进程数
(3)第三行是CPU信息:
%Cpu(s): 5.0 us 用户空间CPU占比 1.7 sy 内核空间CPU占比 0.0 ni 用户进程空间改过优先级的进程CPU占比 93.0 id 空闲CPU占比 0.0 wa IO等待占用CPU的百分比 0.3 hi 硬中断(Hardware IRQ)CPU占比 0.0 si 软中断(Software Interrupts)CPU占比 0.0 st -
(4)第四行是内存信息:
KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers / / / / 物理内存总量 使用中总量 空闲总量 缓存的内存量
(5)第五行是swap交换分区信息:
KiB Swap: 1046524 total, 280708 used, 765816 free, 365556 cached Mem / / / / 交换区总量 使用中总量 空闲总量 缓存的内存量
可用内存=free + buffer + cached
对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,
第四行中空闲内存总量(free)是内核还未纳入其管控范围的数量。
纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。
2、进程(任务)状态监控
第七行及以下显示了各进程(任务)的状态监控。各列所代表的含义如下:
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 进程名称(命令名/命令行)
三、top交互命令
[Space] 立即刷新显示 [c] 切换显示命令名称和完整命令行 [h] 显示帮助画面,给出一些简短的命令总结说明 [q] 退出程序 [k] 杀死某进程。你会被提示输入进程 ID 以及要发送给它的信号。 [n] 改变显示的进程数量。你会被提示输入数量。 [1] 多核cpu分开显示 排序 [u] 按用户排序。 [M] 根据驻留内存大小进行排序 [P] 根据CPU使用百分比大小进行排序 [T] 根据时间/累计时间进行排序 [o]或者[O] 改变显示项目的顺序 [r] 重新安排一个进程的优先级别 [s] 改变两次刷新之间的延迟时间(单位为s) [f]或者[F] 从当前显示中添加或者删除项目 [S] 切换到累计模式 [l] 切换显示平均负载和启动时间信息 [m] 切换显示内存信息 [t] 切换显示进程和CPU状态信息 [i] 忽略闲置和僵死进程。这是一个开关式命令。 [W] 将当前设置写入~/.toprc文件中