top命令即可以监控操作系统CPU、内存、Swap的使用情况,也可以监控进程的详细信息,默认按照CPU的使用率排序。 top返回结果示例如下:
top - 10:12:21 up 5 days, 22:31, 4 users, load average: 1.00, 1.00, 0.78
Tasks: 731 total, 1 running, 730 sleeping, 0 stopped, 0 zombie
%Cpu(s): 1.7 us, 0.0 sy, 0.0 ni, 98.3 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
MiB Mem : 257841.3 total, 1887.5 free, 45581.6 used, 210372.2 buff/cache
MiB Swap: 8192.0 total, 8188.7 free, 3.3 used. 210450.4 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
908076 mysql 20 0 193.0g 42.4g 44088 S 100.3 16.8 228:10.34 mysqld
823137 root 20 0 6187564 83772 51636 S 6.6 0.0 6:36.12 dockerd
822938 root 20 0 3278696 58500 35420 S 0.7 0.0 38:37.69 containerd
1483 root 20 0 239280 9260 8136 S 0.3 0.0 0:19.16 accounts-daemon
928343 root 20 0 9936 4576 3240 R 0.3 0.0 0:00.04 top
......
第一行 10:12:21:当前系统时间 up 5 days:自上一次系统启动后到现在的运行天数 4 users:登录到系统的用户数 load average:过去1分钟、5分钟、15分钟,系统负载的平均值 第二行 total:系统进程总数 running:处于运行状态的进程数 sleeping:处于休眠状态的进程数 stopped:处于被停止状态的进程数 zombie:处于僵尸状态进程数 第三行 us:用户进程占用CPU的百分比 sy:系统进程占用CPU的百分比 ni:优先级被改变过的进程占用CPU的百分比 id:空闲CPU占用的百分比 wa:IO等待占用CPU的百分比 hi:硬件中断占用CPU的百分比 si:软件中断占用CPU的百分比 st:虚拟化环境占用CPU的百分比 需要重点关注CPU的使用率,当us值较高时,说明用户进程消耗CPU时间较多,如果长时间超过50%时,应尽快优化应用服务。当sy值较高时,说明系统进程消耗CPU时间较多,比如可能是操作系统配置不合理或者出现操作系统的Bug。当wa值较高时,说明系统IO等待比较严重,比如可能是发生了大量的随机IO访问,IO带宽出现瓶颈。 第四行 total:物理内存总大小,单位为M free:空闲的内存大小 used:已使用的内存大小 buff/cache:已缓存的内存大小 第五行 total:Swap大小 free:空闲的Swap大小 used:已使用的Swap大小 avail Mem:已缓存的Swap大小 进程列表 PID:进程的id USER:进程的拥有者 PR:进程的优先级,值越小越优先执行 NI:进程nice值,正值表示降低进程优先级,负值表示提高进程优先级,nice取值范围为(-20,19),默认情况下,进程的nice值为0 VIRT:进程占用的虚拟内存大小 RES:进程占用的物理内存大小 SHR:进程占用的共享内存大小 S:进程状态,其中S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数 %CPU:进程CPU使用率 %MEM:进程内存使用率 TIME+:进程启动后占用CPU的总时间,即占用CPU使用时间的累加值 COMMAND:进程启动命令名称