zoukankan      html  css  js  c++  java
  • 【操作系统之八】Linux常用命令之top

    一、概念
    Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,且可以通过交互式命令自定义显示内容,类似于Windows的任务管理器.

    二、命令格式

    [root@PCS101 logs]# top
    top - 21:48:39 up  8:57,  2 users,  load average: 0.36, 0.24, 0.14
    Tasks: 322 total,   2 running, 320 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  5.0 us,  1.7 sy,  0.0 ni, 93.0 id,  0.0 wa,  0.3 hi,  0.0 si,  0.0 st
    KiB Mem:   1010504 total,   937416 used,    73088 free,    23708 buffers
    KiB Swap:  1046524 total,   280708 used,   765816 free.   365556 cached Mem
    
      PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND      
     8096 root      20   0  320624  38508  21192 S  1.7  3.8   0:41.03 Xorg         
    13536 tabalt    20   0  697336 104272  56776 S  1.7 10.3   0:08.29 gnome-langu+ 
     9426 tabalt    20   0 1213228  72976  16860 S  1.0  7.2   2:07.27 compiz       
      197 root      20   0       0      0      0 S  0.3  0.0   0:36.13 kworker/0:2  
     1009 root      20   0  303112   3392   1500 S  0.3  0.3   0:00.93 polkitd      
     9670 tabalt    20   0  325932   4300   2256 S  0.3  0.4   0:40.27 vmtoolsd     
    14016 root      25   5   43940   2408   2000 S  0.3  0.2   0:01.12 http         
    14149 tabalt    20   0  591180  19504  12820 S  0.3  1.9   0:00.45 gnome-termi+ 
        1 root      20   0   33648   1972    744 S  0.0  0.2   0:01.79 init         
        2 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kthreadd     
        3 root      20   0       0      0      0 S  0.0  0.0   0:02.80 ksoftirqd/0  
        4 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0  
        5 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0H 
        7 root      20   0       0      0      0 S  0.0  0.0   0:05.55 rcu_sched    
        8 root      20   0       0      0      0 R  0.0  0.0   0:03.43 rcuos/0      
        9 root      20   0       0      0      0 S  0.0  0.0   0:00.00 rcuos/1      
       10 root      20   0       0      0      0 S  0.0  0.0   0:00.00 rcuos/2

    1、系统信息统计

    前五行是系统整体状态的统计信息展示区域。

    (1)第一行显示服务器概况
    如下所示,第一行列出了服务器运行了多长时间,当前有多少个用户登录,服务器的负荷情况等,使用uptime命令能获得同样的结果。

    top - 21:48:39 up  8:57,  2 users,  load average: 0.36, 0.24, 0.14
           /         /        /                
       系统时间  运行时长   当前登录用户数  平均负载(1分钟、5分钟、15分钟)

    平均负载的值越小代表系统压力越小,越大则代表系统压力越大。通常,我们会以最后一个数值,也就是15分钟内的平均负载作为参考来评估系统的负载情况。

    对于只有单核cpu的系统,1.0是该系统所能承受负荷的边界值,大于1.0则有处理需要等待。
    一个单核cpu的系统,平均负载的合适值是0.7以下。如果负载长期徘徊在1.0,则需要考虑马上处理了。超过1.0的负载,可能会带来非常严重的后果。
    当然,多核cpu的系统是在前述值的基础上乘以cpu内核的个数。如对于多核cpu的系统,有N个核则所能承受的边界值为N.0。
    load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

    可以使用如下命令来查看每个处理器的信息:

    cat /proc/cpuinfo

    如果只想计算有多少个cpu内核,可以使用如下命令:

    cat /proc/cpuinfo | grep 'model name' | wc -l

    (2)第二行是进程信息:

    Tasks: 322 total,   2 running, 320 sleeping,   0 stopped,   0 zombie
            /                /            /             /            /
        进程总数      正运行进程数    睡眠进程数   停止进程数    僵尸进程数

    (3)第三行是CPU信息:

    %Cpu(s):  
    5.0 us      用户空间CPU占比
    1.7 sy      内核空间CPU占比
    0.0 ni      用户进程空间改过优先级的进程CPU占比
    93.0 id     空闲CPU占比
    0.0 wa      IO等待占用CPU的百分比
    0.3 hi      硬中断(Hardware IRQ)CPU占比
    0.0 si      软中断(Software Interrupts)CPU占比
    0.0 st      - 

    (4)第四行是内存信息:

    KiB Mem:   1010504 total,   937416 used,    73088 free,    23708 buffers
                    /                /                /                /
                物理内存总量      使用中总量        空闲总量        缓存的内存量

    (5)第五行是swap交换分区信息:

    KiB Swap:  1046524 total,   280708 used,   765816 free,   365556 cached Mem
                    /                /                /                /
                交换区总量      使用中总量        空闲总量        缓存的内存量

    可用内存=free + buffer + cached

    对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
    第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,
    第四行中空闲内存总量(free)是内核还未纳入其管控范围的数量。
    纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

    2、进程(任务)状态监控
    第七行及以下显示了各进程(任务)的状态监控。各列所代表的含义如下:

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

    三、top交互命令

    [Space] 立即刷新显示 
    [c] 切换显示命令名称和完整命令行
    [h] 显示帮助画面,给出一些简短的命令总结说明
    [q] 退出程序
    [k]  杀死某进程。你会被提示输入进程 ID 以及要发送给它的信号。 
    [n]  改变显示的进程数量。你会被提示输入数量。 
    [1] 多核cpu分开显示
    
    排序
    [u] 按用户排序。 
    [M] 根据驻留内存大小进行排序
    [P] 根据CPU使用百分比大小进行排序
    [T] 根据时间/累计时间进行排序
    [o]或者[O] 改变显示项目的顺序
    [r] 重新安排一个进程的优先级别
    [s] 改变两次刷新之间的延迟时间(单位为s)
    [f]或者[F] 从当前显示中添加或者删除项目
    [S] 切换到累计模式
    [l] 切换显示平均负载和启动时间信息
    [m] 切换显示内存信息
    [t] 切换显示进程和CPU状态信息
    [i] 忽略闲置和僵死进程。这是一个开关式命令。
    [W] 将当前设置写入~/.toprc文件中
  • 相关阅读:
    网站设计的65条原则
    汇编指令: VERW、WAIT、WBINVD、WRSHR、WRMSR、XADD、XBTS、XCHG、
    openssl编程入门(含完整可编译和运行示例)
    揭开Linux的Swap之谜
    成功的 Web 应用系统性能测试
    加密通讯协议SSL编程周立发
    Google Sparse Hash
    测试 Linux 的可靠性
    进程绑定CPU简单应用
    mylarge&mymedium&mysmall&myinnodbheavy4G
  • 原文地址:https://www.cnblogs.com/cac2020/p/11772107.html
Copyright © 2011-2022 走看看