一、概述
top
命令是Linux
下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows
的任务管理器。top
是一个动态显示过程,即可以通过用户按键来不断刷新当前状态。如果在前台执行该命令,它将独占前台,直到用户终止该程序为止。比较准确的说,top
命令提供了实时的对系统处理器的状态监视。它将显示系统中CPU
最“敏感”的任务列表。该命令可以按CPU
使用、内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定。
二、具体使用
$top
top - 10:22:48 up 152 days, 20:25, 2 users, load average: 0.24, 0.29, 0.34
Tasks: 108 total, 1 running, 107 sleeping, 0 stopped, 0 zombie
%Cpu(s): 4.8 us, 2.1 sy, 0.0 ni, 93.1 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 3688712 total, 193148 free, 2422560 used, 1073004 buff/cache
KiB Swap: 3929680 total, 2163980 free, 1765700 used. 951672 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1811 root 10 -10 175936 37612 4176 S 5.3 1.0 7227:49 AliYunDunMonito 6597 root 20 0 3624088 454092 6772 S 4.3 12.3 345:38.03 java 1678 admin 20 0 3429664 768524 17308 S 3.0 20.8 11475:06 java 1800 root 10 -10 113488 5888 3952 S 1.7 0.2 1311:12 AliYunDun
23841 polkitd 20 0 2800188 37596 1028 S 1.3 1.0 1207:32 mysqld
23070 polkitd 20 0 2889992 392048 7676 S 1.0 10.6 993:37.55 mysqld 1021 root 20 0 1374488 39624 5736 S 0.7 1.1 414:17.19 dockerd
第一行
- 09:14:56 : 系统当前时间
- 264 days, 20:56 : 系统开机到现在经过了多少时间
- 1 users : 当前2用户在线
- load average: 0.02, 0.04, 0.00: 系统1分钟、5分钟、15分钟的CPU负载信息
第二行
Tasks
:任务;total
:很好理解,就是当前的进程数。running
:正在运行的进程数sleeping
:睡眠的进程数stopped
:停止的进程数zombie
:僵死的进程数
第三行
Cpu(s)
:表示这一行显示CPU总体信息us
:用户态进程占用CPU时间百分比,不包含renice值为负的任务占用的CPU的时间。sy
:内核占用CPU时间百分比ni
:改变过优先级的进程占用CPU的百分比id
:空闲CPU时间百分比wa
:等待I/O的CPU时间百分比hi
:CPU硬中断时间百分比si
:CPU软中断时间百分比
注:这里显示数据是所有cpu的平均值,如果想看每一个cpu的处理情况,按1即可;折叠,再次按1;
第四行
Men
:内存的意思total
:物理内存总量used
:使用的物理内存量free
:空闲的物理内存量buffers
:用作内核缓存的物理内存量
第五行
Swap
:交换空间total
:交换区总量used
:使用的交换区量free
:空闲的交换区量cached
:缓冲交换区总量
进程信息
再下面就是进程信息:
PID
:进程的IDUSER
:进程所有者PR
:进程的优先级别,越小越优先被执行NInice
:值VIRT
:进程占用的虚拟内存RES
:进程占用的物理内存SHR
:进程使用的共享内存S
:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数%CPU
:进程占用CPU的使用率%MEM
:进程使用的物理内存和总内存的百分比TIME+
:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。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命令;
四、实例
实例1:多核CPU监控
在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况;
[rdtfr@bl685cb4-t ^]$ top
top - 09:10:44 up 20 days, 16:51, 4 users, load average: 3.82, 4.40, 4.40
Tasks: 1201 total, 10 running, 1189 sleeping, 0 stopped, 2 zombie
Cpu0 : 1.3%us, 2.3%sy, 0.0%ni, 96.4%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu1 : 1.3%us, 2.6%sy, 0.0%ni, 96.1%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu2 : 1.0%us, 2.0%sy, 0.0%ni, 92.5%id, 0.0%wa, 0.0%hi, 4.6%si, 0.0%st
Cpu3 : 3.9%us, 7.8%sy, 0.0%ni, 83.2%id, 0.0%wa, 0.0%hi, 5.2%si, 0.0%st
Cpu4 : 4.2%us, 10.4%sy, 0.0%ni, 63.8%id, 0.0%wa, 0.0%hi, 21.5%si, 0.0%st
Cpu5 : 6.8%us, 12.7%sy, 0.0%ni, 80.5%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Cpu6 : 2.9%us, 7.2%sy, 0.0%ni, 85.3%id, 0.0%wa, 0.0%hi, 4.6%si, 0.0%st
Cpu7 : 6.2%us, 13.0%sy, 0.0%ni, 75.3%id, 0.0%wa, 0.0%hi, 5.5%si, 0.0%st
Mem: 32943888k total, 32834216k used, 109672k free, 642704k buffers
Swap: 35651576k total, 5761928k used, 29889648k free, 16611500k cached
实例2:高亮显示当前运行进程
在top基本视图中,按键盘“b”(打开/关闭加亮效果);
实例3:显示完整的程序命令
命令:top -c
[rdtfr@bl685cb4-t ^]$ top -c
top - 09:14:35 up 20 days, 16:55, 4 users, load average: 5.77, 5.01, 4.64
Tasks: 1200 total, 5 running, 1192 sleeping, 0 stopped, 3 zombie
Cpu(s): 4.4%us, 6.0%sy, 0.0%ni, 83.8%id, 0.2%wa, 0.0%hi, 5.5%si, 0.0%st
Mem: 32943888k total, 32842896k used, 100992k free, 591484k buffers
Swap: 35651576k total, 5761808k used, 29889768k free, 16918824k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
2013 apache 18 0 403m 88m 5304 S 25.0 0.3 6:37.44 /usr/sbin/httpd
18335 pubtest 22 0 65576 996 728 R 7.8 0.0 0:00.24 netstat -naltp
16499 rdtfare 15 0 13672 2080 824 R 2.6 0.0 0:00.38 top -c
29684 rdtfare 15 0 1164m 837m 14m S 2.3 2.6 148:47.54 ./autodata data1.txt
12976 pubtest 18 0 238m 9000 1932 S 1.6 0.0 439:28.44 tscagent -s TOEV_P
实例4:显示指定的进程信息
命令:top -p <pidid>
/opt/app/tdv1/config#top -p 17265
top - 09:17:34 up 455 days, 17:55, 2 users, load average: 3.76, 4.56, 4.46
Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie
Cpu(s): 7.8%us, 1.9%sy, 0.0%ni, 89.2%id, 0.0%wa, 0.1%hi, 1.0%si, 0.0%st
Mem: 8175452k total, 8103988k used, 71464k free, 268716k buffers
Swap: 6881272k total, 4275424k used, 2605848k free, 6338184k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
17265 tdv1 15 0 56504 828 632 S 0.0 0.0 195:53.25 redis-server
指定进程信息有多个时,需要结合其它工具将回车替换为,(-p 支持pid,pid,pid语法)
命令:top -p pgrep MULTI_PROCESS | tr “\n” ”,” | sed ‘s/,$//’
/opt/app/tdv1$top -p `pgrep java | tr "\\n" "," | sed 's/,$//'`
top - 14:05:31 up 53 days, 2:43, 9 users, load average: 0.29, 0.34, 0.22
Tasks: 3 total, 0 running, 3 sleeping, 0 stopped, 0 zombie
Cpu(s): 5.9%us, 8.2%sy, 0.0%ni, 86.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 66082088k total, 29512860k used, 36569228k free, 756352k buffers
Swap: 32767992k total, 1019900k used, 31748092k free, 15710284k cachedPID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 27855 rdtfare 20 0 4454m 1.3g 5300 S 0.7 2.0 338:31.37 java2034 jenkins 20 0 18.3g 5.2g 5284 S 0.3 8.2 56:02.38 java 12156 rdtfare 20 0 4196m 1.2g 12m S 0.3 2.0 86:34.62 java
实例5:显示特定用户的进程
命令:top -u <username>
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1811 root 10 -10 175936 37612 4176 S 6.0 1.0 7229:28 AliYunDunMonito 6597 root 20 0 3624088 456868 6772 S 4.3 12.4 346:53.39 java 1800 root 10 -10 113488 5888 3952 S 1.0 0.2 1311:34 AliYunDun 941 root 20 0 1175428 22412 4524 S 0.7 0.6 448:29.44 containerd 9 root 20 0 0 0 0 S 0.3 0.0 233:49.32 rcu_sched 328 root 20 0 0 0 0 S 0.3 0.0 23:26.07 jbd2/vda1-8