TOP命令详解

一、top命令介绍

  相信每个运维人员都遇到过的事情就是服务器的负载突然飙升,碰到这种情况,大家第一反应一定是登到服务器上,先敲一个top命令看看load average吧。在Linux操作系统中,top是使用最频繁,也是信息比较全的一个命令,它对于所有正在运行的进行和系统负荷提供不断更新的概览信息,包括系统负载、CPU利用分布情况、内存使用、每个进程的资源占用情况等信息,今天这篇文章和大家说说怎么看懂top命令。

二、top命令输出结果解析

[root@centos ~]# top
top - 14:51:24 up 57 min,  3 users,  load average: 0.00, 0.01, 0.05
Tasks: 206 total,   2 running, 204 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.7 sy,  0.0 ni, 99.3 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  2047268 total,   135980 free,   765700 used,  1145588 buff/cache
KiB Swap:  2097148 total,  2096884 free,      264 used.  1083728 avail Mem PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                 403 root      20   0       0      0      0 S  0.3  0.0   0:01.97 xfsaild/dm-0
27767 root      20   0  162100   2348   1580 R  0.3  0.1   0:00.04 top                                                                     1 root      20   0  128540   7148   4220 S  0.0  0.3   0:02.68 systemd                                                                 2 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kthreadd                                                                4 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0H                                                            6 root      20   0       0      0      0 S  0.0  0.0   0:04.43 ksoftirqd/0                                                             7 root      rt   0       0      0      0 S  0.0  0.0   0:00.00 migration/0                                                             8 root      20   0       0      0      0 S  0.0  0.0   0:00.00 rcu_bh                                                                  9 root      20   0       0      0      0 R  0.0  0.0   0:02.56 rcu_sched                                                               10 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 lru-add-drain                                                           11 root      rt   0       0      0      0 S  0.0  0.0   0:00.27 watchdog/0                                                              13 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kdevtmpfs                                                               14 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 netns                                                                   15 root      20   0       0      0      0 S  0.0  0.0   0:00.00 khungtaskd                                                              16 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 writeback                                                               17 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kintegrityd                                                             18 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 bioset                                                                  19 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 bioset                                                                  20 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 bioset                                                                  21 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kblockd                                                                 22 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 md                                                                      23 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 edac-poller  

top命令输出了很多参数,真正的服务器负载情况我们要综合其他参数一起看,运行结果可以分为两部分:
第一部分是前5行,是系统整体的统计信息
第二部分是第8行开始的进程信息,我们从上往下逐行依次进行说明。

2.1、系统整体的统计信息

第一行:

top - 14:51:24 up 57 min,  3 users,  load average: 0.00, 0.01, 0.05
  • top:当前时间
  • up:机器运行了多长时间
  • users:当前登录用户数
  • load average:系统负载,即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

这里具体需要关注的还是load average三个数值。先来说说定义吧:在一段时间内,CPU正在处理以及等待CPU处理的进程数之和。三个数字分别代表了1分钟,5分钟,15分钟的统计值,这个数值的确能反应服务器的负载情况。但是,这个数值高了也并不能直接代表这台机器的性能有问题,可能是因为正在进行CPU密集型的计算,也有可能是因为I/O问题导致运行队列堵了。所以,当我们看到这个数值飙升的时候,还得具体问题具体分析。大家都知道,一个CPU在一个时间片里面只能运行一个进程,CPU核数的多少直接影响到这台机器在同时间能运行的进程数。所以一般来说Load Average的数值别超过这台机器的总核数,就基本没啥问题。
第二行:

Tasks: 206 total,   2 running, 204 sleeping,   0 stopped,   0 zombie
  • Tasks:当前有多少进程
  • running:正在运行的进程数
  • sleeping:正在休眠的进程数
  • stopped:停止的进程数
  • zombie:僵尸进程数

这里running越多,服务器自然压力就越大

第三行:

%Cpu(s):  0.0 us,  0.7 sy,  0.0 ni, 99.3 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
  • us:用户空间占CPU的百分比(像shell程序、各种语言的编译器、各种应用、web服务器和各种桌面应用都算是运行在用户地址空间的进程,这些程序如果不是处于idle状态,那么绝大多数的CPU时间都是运行在用户态)
  • sy: 内核空间占CPU的百分比(所有进程要使用的系统资源都是由Linux内核处理的,对于操作系统的设计来说,消耗在内核态的时间应该是越少越好,在实践中有一类典型的情况会使sy变大,那就是大量的IO操作,因此在调查IO相关的问题时需要着重关注它)
  • ni:用户进程空间改变过优先级(ni是nice的缩写,可以通过nice值调整进程用户态的优先级,这里显示的ni表示调整过nice值的进程消耗掉的CPU时间,如果系统中没有进程被调整过nice值,那么ni就显示为0)
  • id: 空闲CPU占用率
  • wa: 等待输入输出的CPU时间百分比(和CPU的处理速度相比,磁盘IO操作是非常慢的,有很多这样的操作,比如,CPU在启动一个磁盘读写操作后,需要等待磁盘读写操作的结果。在磁盘读写操作完成前,CPU只能处于空闲状态。Linux系统在计算系统平均负载时会把CPU等待IO操作的时间也计算进去,所以在我们看到系统平均负载过高时,可以通过wa来判断系统的性能瓶颈是不是过多的IO操作造成的)
  • hi: 硬中断占用百分比(硬中断是硬盘、网卡等硬件设备发送给CPU的中断消息,当CPU收到中断消息后需要进行适当的处理(消耗CPU时间)。)
  • si:软中断占用百分比(软中断是由程序发出的中断,最终也会执行相应的处理程序,消耗CPU时间)
  • st:steal time

第四行:

KiB Mem :  2047268 total,   135980 free,   765700 used,  1145588 buff/cache
  • total:物理内存总量
  • free:空闲内存量
  • used:使用的内存量
  • buffer/cache:用作内核缓存的内存量

第五行:

KiB Swap:  2097148 total,  2096884 free,      264 used.  1083728 avail Mem 
  • total:交换区内存总量
  • free:空闲交换区总量
  • used:使用的交换区总量
  • buffer/cache:缓冲的交换区总量

第四第五行分别是内存信息和swap信息,所有程序的运行都是在内存中进行的,所以内存的性能对与服务器来说非常重要。不过当内存的free变少的时候,其实我们并不需要太紧张。真正需要看的是Swap中的used信息。Swap分区是由硬盘提供的交换区,当物理内存不够用的时候,操作系统才会把暂时不用的数据放到Swap中。所以当这个数值变高的时候,说明内存是真的不够用了。

2.2、进程信息

 PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                 403 root      20   0       0      0      0 S  0.3  0.0   0:01.97 xfsaild/dm-0
27767 root      20   0  162100   2348   1580 R  0.3  0.1   0:00.04 top                     
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 命令名/命令行

默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列,还有一些参数,例如:

PPID 父进程id
GROUP   进程所有者的组名
SWAP:   进程使用的虚拟内存中被换出的大小
CODE    可执行代码占用的物理内存大小,单位kb
DATA    可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
nFLT    页面错误次数
nDRT    最后一次写入到现在,被修改过的页面数。
WCHAN   若该进程在睡眠,则显示睡眠中的系统函数名
Flags   任务标志

三、top命令使用

3.1、更改显示内容

通过按 f 键可以编辑显示内容,按f键后,会出现下图:

根据上图可知:
①当前是按照%CPU这一列来排序的
②可以通过上、下键来选择
③按右键可以选择整个列,然后按上、下键来移动整个列的显示位置,前移或后移,按回车确定
④按空格键来显示或隐藏该列,带*的是显示,不带*的是不显示
⑤按s键可以将当前列设置为排序列
⑥按q键退出

3.2、top常用参数

top命令的格式为:

top [选项]

top命令常用的选项参数:

选项   功能
-d  指定每两次屏幕信息刷新之间的时间间隔,如希望每秒刷新一次,则使用:top -d 1
-p  通过指定PID来仅仅监控某个进程的状态
-S  指定累计模式
-s  使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险
-i  使top不显示任何闲置或者僵死的进程
-c  显示整个命令行而不只是显示命令名

例如:

top   每隔3秒显式所有进程的资源占用情况
top -d 1  每隔1秒显式所有进程的资源占用情况
top -c    每隔3秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)
top -p 28820 -p 38830   每隔3秒显示pid是28820和pid是38830的两个进程的资源占用情况
top -d 2 -c -p 69358  每隔2秒显示pid是69358的进程的资源使用情况,并显式该进程启动的命令行参数

3.3、top的交互命令

默认进入top时,各进程是按照CPU的占用量来排序的

【1】敲top后,按键盘数字“1”可以监控每个逻辑CPU的状况:

【2】敲top后,输入u,然后输入用户名,则可以查看相应的用户进程;

【3】敲top后,top命令默认以K为单位显示内存大小,我们可以通过大写字母E来切换内存信息区域的显示单位,如下按一下E切换到MB

再按一下E切换到GB:

【4】敲top后,输入h进入top命令的帮助文档,了解更多关于top的用法。

top当然是我们最常见的查看系统状况的命令。其他命令还有很多,比如vmstat,w,uptime ,iostat这些都是常用的命令。

TOP命令参数详解-(转)相关推荐

  1. Linux top命令参数详解

    Linux top命令参数详解 生产环境系统运行慢,出现无法响应通常原因主要还在于分析CPU.内存.磁盘使用率情况,并结合命令查找出具体进程,并在进程中进一步分析主要因子情况,渗透到对于其中包含线程占 ...

  2. top命令参数详解(linux top命令的用法详细详解)

    通过top命令可以有效的发现系统的缺陷出在哪里.是内存不够.CPU处理能力不够.IO读写过高. top命令输出长这样: top命令参数详解(linux top命令的用法详细详解) 以下解析一下各个字段 ...

  3. linux下top命令参数详解

    linux下top命令参数详解 top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.下面详细介绍它的使用方法. 内存信息.内容如下: ...

  4. top命令参数详解_Linux、AIX的top命令各项指标详解(非原创侵删)

    一.Linux下监控服务器状态命令--top:各数据详解 top命令作用是实时现实服务器当前CPU.内存.负载.进程等信息 第一行 00:09:14 - 当前系统时间 1days, 13:14 - 系 ...

  5. top命令参数详解。

    TOP是一个常用的系统性能监视工具,可以显示系统资源的使用情况,并按照CPU使用率.内存使用率等指标进行排序.下面是常用的TOP命令参数及其含义的详细解释: 1. -d seconds:指定TOP命令 ...

  6. Linux 的 top命令参数详解 PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

    Linux 的 top命令详解 这张图是真实的阿里云云服务器上,使用了top命令之后的信息. 1.上半部分显示了整体系统负载情况 1.1 top 第一行: 从左到右依次为当前系统时间,系统运行的时间, ...

  7. Linux中top命令参数详解、常用快捷键

    1.命令 1.简介 top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.  显示系统当前的进程和其他状况: top是一个动态显示过程 ...

  8. TOP命令参数详解---10分钟学会top用法

    TOP命令详解 一.top命令介绍   相信每个运维人员都遇到过的事情就是服务器的负载突然飙升,碰到这种情况,大家第一反应一定是登到服务器上,先敲一个top命令看看load average吧.在Lin ...

  9. Linux系统内核介绍及Linux系统运行级别,uname,vmstat,top命令参数详解 和一些排查案例

    Linux系统内核:内核是操作系统的核心,有很多基本功能,负责管理系统的进程 内存设备驱动程序 文件和网络系统,决定着系统的性能和稳定性 Linux内核相关介绍: 内存管理(Linux采用虚拟内存) ...

最新文章

  1. 分布式协调组件ZooKeeper的技术理论剖析-综合组件环境实战
  2. Retrofit2 multpart多文件上传详解
  3. python实现维吉尼亚加密法
  4. 免费都不管用,Win10升级在中国怎么就这么难?
  5. c 调用java程序_C ++可以调用Java代码吗?
  6. C - 查找回文质数
  7. win8恢复我的计算机较早时间点,Win8系统的重置和刷新功能 -电脑资料
  8. Linux学习笔记之权限与命令之间的关系(重要)及文件与目录知识总结
  9. c语言实现61850协议,IEC61850开发库 libIEC61850提供了用C语言编写的IEC 61850 / MMS - 下载 - 搜珍网...
  10. python读取svg转emf_玩玩矢量图标,SVG转换EMF
  11. linux虚拟核显,PVE直通核显搭建虚拟Win10 HTPC避坑指南
  12. 测绘大王的GPS盛宴
  13. uva10105(数论多项式展开公式)
  14. 拆解SSK SCRM330 USB3.0读卡器 GL3233 固件 0819
  15. 做大数据可视化分析的软件和工具有哪些?
  16. SQL Server数据库实操 第五波 完整性约束和触发器
  17. AMD RDNA Architecture - AMD RDNA 架构
  18. 高等工程数学 —— 第一章 (1)距离与范数
  19. 物理思维在计算机中的应用,思维导图学物理 学会用大脑的语言进行思考
  20. window+deepin双系统安装

热门文章

  1. matlab select函数,select函数
  2. PPTV的走向:“卖身”求生或成唯一选择
  3. 医院等级评审,离不开不良事件上报系统
  4. java excel导入jsp_jsp页面导入excel文件的步骤及配置
  5. 每月10美元的付费iCloud存储空间现在加量不加价
  6. 微信分享相关:报错“微信:包名不对,请检查包名是否与开放平台填写一致”
  7. 未来智能设备不再以视觉展现为主!
  8. sketchbook手机版_sketchbook pro手机版
  9. 黄金螺旋线在界面设计中的运用
  10. IAR下载报错 “Fatal error: Failed to connect to CPU Session aborted!”