一、top命令
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。
top显示系统当前的进程和其他状况,是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.
比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.
wang@wang:~/workpalce/git$ top top - 15:20:08 up 5:11, 1 user, load average: 0.00, 0.00, 0.00 Tasks: 291 total, 1 running, 290 sleeping, 0 stopped, 0 zombie %Cpu(s): 2.1 us, 2.1 sy, 0.0 ni, 95.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st KiB Mem : 2061712 total, 279984 free, 845504 used, 936224 buff/cache KiB Swap: 2094076 total, 2094076 free, 0 used. 925816 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1324 root 20 0 259472 67348 29672 S 12.6 3.3 2:34.22 Xorg 1856 wang 20 0 328808 112944 81768 S 4.7 5.5 2:42.80 compiz 3552 wang 20 0 154824 51544 40684 S 4.3 2.5 0:37.66 gnome-terminal- 7 root 20 0 0 0 0 S 1.0 0.0 0:24.70 rcu_sched 1289 mysql 20 0 573808 163916 17164 S 0.7 8.0 1:27.94 mysqld 2032 wang 20 0 53764 23568 21520 S 0.7 1.1 0:46.55 vmtoolsd 1022 root 20 0 25064 9432 7808 S 0.3 0.5 0:46.94 vmtoolsd 1331 root 20 0 136224 27212 22296 S 0.3 1.3 0:03.13 php-fpm7.0 1705 wang 20 0 119348 44812 23124 S 0.3 2.2 0:08.57 fcitx 2015 root 20 0 133740 28552 22628 S 0.3 1.4 0:02.77 apache2 2020 wang 20 0 65392 18824 16600 S 0.3 0.9 0:00.24 polkit-gnome-au 2145 zabbix 20 0 96464 4600 3008 S 0.3 0.2 0:04.84 zabbix_server 2186 zabbix 20 0 96464 5760 4168 S 0.3 0.3 0:12.76 zabbix_server 2191 zabbix 20 0 96464 1608 28 S 0.3 0.1 0:03.31 zabbix_server 2194 zabbix 20 0 96464 3936 2356 S 0.3 0.2 0:04.51 zabbix_server 5917 wang 20 0 9836 3580 2940 R 0.3 0.2 0:00.05 top 1 root 20 0 24132 5004 3592 S 0.0 0.2 0:07.48 systemd 2 root 20 0 0 0 0 S 0.0 0.0 0:00.08 kthreadd
第一行是任务队列信息:
15:20:08 当前时间 up 5:21 系统运行时间,格式为时:分 1 user 当前登录用户数 load average: 0.00, 0.00, 0.00 系统负载,即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。
第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行:
total 进程总数 running 正在运行的进程数 sleeping 睡眠的进程数 stopped 停止的进程数 zombie 僵尸进程数 Cpu(s): 2.1% us 用户空间占用CPU百分比 2.1% sy 内核空间占用CPU百分比 0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比 95.9% id 空闲CPU百分比 0.0% wa 等待输入输出的CPU时间百分比 0.0%hi: 硬件CPU中断占用百分比 0.0%si: 软中断占用百分比 0.0%st: 虚拟机占用百分比
最后两行为内存信息:
Mem:
2061712 total 物理内存总量
845504 used 使用的物理内存总量
279984 free 空闲内存总量
936224 buffers 用作内核缓存的内存量
Swap:
2094076 total 交换区总量
0k used 使用的交换区总量
2094076 free 空闲交换区总量
925816 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
常用操作:
top //每隔5秒显式所有进程的资源占用情况 top -d 2 //每隔2秒显式所有进程的资源占用情况 top -c //每隔5秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名) top -p 12345 -p 6789 //每隔5秒显示pid是12345和pid是6789的两个进程的资源占用情况 top -d 2 -c -p 123456 //每隔2秒显示pid是12345的进程的资源使用情况,并显式该进程启动的命令行参数