学习笔记

Study notes

Linux top 命令详解

云逐梦19492022-03-30 16:26:00返回列表

Linux top命令用于实时显示 process 的动态。

一、前言

        top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top命令可以动态显示进程的资源使用情况,即可以通过用户按键来不断刷新当前状态。如果在前台执行该命令,它将独占前台,直到用户终止该程序为止。比较准确的说,top命令提供了实时的对系统处理器的状态监视,它将显示系统中CPU最“敏感”的任务列表,该命令可以按CPU使用、内存使用和执行时间来对任务进行排序,而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定。

、top详解

    1、命令格式

top [-] [d delay] [q] [c] [S] [s] [i] [n] [b]

    2、命令参数

d : 改变显示的更新速度,或是在交谈式指令列( interactive command)按 s
q : 没有任何延迟的显示速度,如果使用者是有 superuser 的权限,则 top 将会以最高的优先序执行
c : 切换显示模式,共有两种模式,一是只显示执行档的名称,另一种是显示完整的路径与名称
S : 累积模式,会将己完成或消失的子进程 ( dead child process ) 的 CPU time 累积起来
s : 安全模式,将交谈式指令取消, 避免潜在的危机
i : 不显示任何闲置 (idle) 或无用 (zombie) 的进程
n : 更新的次数,完成后将会退出 top
b : 批次档模式,搭配 "n" 参数一起使用,可以用来将 top 的结果输出到档案内

    3、实例介绍

    实例一:显示进程信息

    命令:

    top

top - 10:54:45 up 10 days, 21:33, 19 users,  load average: 0.32, 0.34, 0.18
Tasks: 537 total,   1 running, 536 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.8%us,  0.8%sy,  0.0%ni, 98.3%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  16466428k total, 15166160k used,  1300268k free,  4580980k buffers
Swap:  4194300k total,        0k used,  4194300k free,  5448388k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                                 
    1 root      20   0 19528 1632 1312 S  0.0  0.0   1:58.86 init                                                     
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.02 kthreadd                                                 
    3 root      RT   0     0    0    0 S  0.0  0.0   0:01.73 migration/0                                              
    4 root      20   0     0    0    0 S  0.0  0.0   0:09.02 ksoftirqd/0                                              
    5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0

说明:

统计信息区:前五行是当前系统情况整体的统计信息


第一行,系统任务统计信息,同 uptime 命令的执行结果,具体参数说明情况如下:

    10:54:45 — 当前系统时间

    up 10 days, 21:33 — 系统已经运行了10天21小时33分钟(在这期间系统没有重启过!)

    19 users — 当前有19个用户登录系统

    load average: 0.32, 0.34, 0.18 — load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。

    load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

    

     系统平均负载:在特定时间间隔内运行队列中的平均进程树。简单理解为,一段时间内,等待 CPU 处理的进程个数。

    1分钟的系统平均负载:瞬时的负载指标

    5分钟、15分钟的平均负载:持续的负载指标


   一般认为,单核满载的值为 1;那么,

    当系统负载 > CPU核心 * 0.7 时,这是需要进行一定的优化处理了

    当系统负载 > CPU核心 * 1.5 时,基本上是不得不进行优化处理了


第二行,Tasks—进程统计信息,具体信息说明如下:

    537 total — 系统现在共有537个进程   

    1 running — 其中处于运行中的有1个

    536 sleeping — 536个在休眠(sleep)

    0 stopped — stoped状态的有0个   

    0 zombie — zombie状态(僵尸)的有0个


  第三行,cpu状态信息,具体属性说明如下:

    0.8%us — 用户空间占用CPU的百分比。

    0.8%sy — 内核空间占用CPU的百分比。

    0.0%ni — 改变过优先级的进程占用CPU的百分比

    98.3%id — 空闲CPU百分比

    0.0%wa — IO等待占用CPU的百分比

    0.0%hi — 硬中断(Hardware IRQ)占用CPU的百分比

    0.0%si — 软中断(Software Interrupts)占用CPU的百分比

 0.0%st — 全称 Steal Time,该项指标只对虚拟机有效,表示分配给当前虚拟机的 CPU 时间之中,被同一台物理机上的其他虚拟机偷走的时间百分比


  第四行,内存统计信息,具体信息如下:

    16466428k total — 物理内存总量

    15166160k used — 已使用的物理内存总量

    1300268k free — 空闲物理内存总量

    4580980k buffers — 用作内核缓存的物理内存


  第五行,swap交换分区统计信息,具体信息说明如下:

    4194300k total — 交换区总量

    0k used — 已使用的交换区总量

    4194300k free — 空闲交换区总量

    5448388k cached — 缓冲的交换区总量


    备注:

    第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

    如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存。

    对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。


  第六行,空行。

  第七行以下:各进程(任务)的状态监控,项目列信息说明如下:

    PID — 进程id

    USER — 进程所有者

    PR — 进程优先级

    NI — nice值。负值表示高优先级,正值表示低优先级。越小优先级越高,最小-20,最大20(用户设置最大19)

    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 — 进程名称(命令名/命令行)


 PPID — 父进程id

    RUSER — Real user name

    UID — 进程所有者的用户id

    GROUP — 进程所有者的组名

    TTY — 启动进程的终端名。不是从终端启动的进程则显示为 ?

    P — 最后使用的CPU,仅在多CPU环境下有意义

    TIME — 进程使用的CPU时间总计,单位秒

    SWAP — 进程使用的虚拟内存中,被换出的大小,单位kb

    RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

    CODE — 可执行代码占用的物理内存大小,单位kb

    DATA — 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb

 nFLT — 页面错误次数

    nDRT — 最后一次写入到现在,被修改过的页面数

 WCHAN — 若该进程在睡眠,则显示睡眠中的系统函数名

    Flags — 任务标志,参考 sched.h

    3、实例介绍

        实例一:多核CPU监控

        命令:

        top

   1)、在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况,再按数字键1,就会返回到top基本视图界面。

   2)、高亮显示当前运行进程:敲击键盘“b”(打开/关闭加亮效果),可以通过敲击“y”键关闭或打开运行态进程的加亮效果。

   3)、默认进入top时,各进程是按照CPU的占用量来排序的,敲击键盘“x”(打开/关闭排序列的加亮效果)

   4)、通过”shift + >”或”shift + <”可以向右或左改变排序列


        实例二:显示完整命令

        命令:

        top -c

   

        实例三:以批处理模式显示程序信息

        命令:

        top -b

    

        实例四:以累积模式显示程序信息

        命令:

        top -S


        实例五:设置信息更新次数(表示更新2次后终止更新显示)

        命令:

        top -n 2


        实例六:设置信息更新时间(表示更新周期为2秒)

        命令:

        top -d 2


        实例七:显示指定的进程信息

        命令:

        top -p 666


    4、top交互命令

在top 命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了s选项,其中一些命令可能会被屏蔽。

空格/Enter 刷新界面

h/? 显示帮助菜单,给出一些简短的命令总结说明

终止指定的进程

i 忽略闲置和僵死进程。这是一个开关式命令。

q 退出程序

r 重新安排一个进程的优先级别

S 切换到累计模式

s 改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s

f或者F 从当前显示中添加或者删除项目

o或者O 改变显示项目的顺序

l 切换显示平均负载和启动时间信息

m 切换显示内存信息

t 切换显示进程和CPU状态信息

c 切换显示命令名称和完整命令行

M 根据驻留内存大小进行排序

P 根据CPU使用百分比大小进行排序

T 根据时间/累计时间进行排序

    W 将当前设置写入~/.toprc文件中 


    4、linux退出top命令方法

        在top命令运行时退出命令有两种方式:

        1. 在top命令运行的过程中按下键盘的q键可以退出。

        2. 在top命令运行的过程中按下键盘的ctrl+c键也可以退出。


返回
顶部