zoukankan      html  css  js  c++  java
  • Linux 常用命令十二 top

    一、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的进程的资源使用情况,并显式该进程启动的命令行参数
  • 相关阅读:
    JavaSE_11_File类、递归
    JavaSE_10_IO流
    leyou_07_对数据的操作
    JavaSE_09_Map
    JavaSE_08_Collections常用功能
    java 22
    java 22
    java 22
    java 22
    java 22
  • 原文地址:https://www.cnblogs.com/gundan/p/8066000.html
Copyright © 2011-2022 走看看