zoukankan      html  css  js  c++  java
  • linux top详解

    此命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。

    top - 01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48

    Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie

    Cpu(s): 0.3% us, 1.0% sy, 0.0% ni, 98.7% id, 0.0% wa, 0.0% hi, 0.0% si

    Mem: 191272k total, 173656k used, 17616k free, 22052k buffers

    Swap: 192772k total, 0k used, 192772k free, 123988k cached

    PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

    1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd

    14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top

    1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init

    2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0

    3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0

    统计信息区

    前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime 命令的执行结果。其内容如下:

    01:06:48 当前时间

    up 1:22 系统运行时间,格式为时:分

    1 user 当前登录用户数

    load average: 0.06, 0.60, 0.48 系统负载,即任务队列的平均长度。

    三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

    第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:

    Tasks: 29 total 进程总数

    1 running 正在运行的进程数

    28 sleeping 睡眠的进程数

    0 stopped 停止的进程数

    0 zombie 僵尸进程数

    Cpu(s): 0.3% us 用户空间占用CPU百分比

    1.0% sy 内核空间占用CPU百分比

    0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比

    98.7% id 空闲CPU百分比

    0.0% wa 等待输入输出的CPU时间百分比

    0.0% hi

    0.0% si

    最后两行为内存信息。内容如下:

    Mem: 191272k total 物理内存总量

    173656k used 使用的物理内存总量

    17616k free 空闲内存总量

    22052k buffers 用作内核缓存的内存量

    Swap: 192772k total 交换区总量

    0k used 使用的交换区总量

    192772k free 空闲交换区总量

    123988k 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

    默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通过下面的快捷键来更改显示内容。

    更改显示内容:

    1。 通过 f 键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z 即可显示或隐藏对应的列,最后按回车键确定。

    2。 按 o 键可以改变列的显示顺序。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z 可以将相应的列向左移动。最后按回车键确定。

    3。 按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的 R 键可以将当前的排序倒转。

     

    --------------------------详细介绍----------------------------

    top 是個挺不錯的程序觀察工具!不同於 ps 是靜態的結果輸出, top 這個程式可以持續的監測 (monitor) 整個系統的程序工作狀態,例如上面的範例一所示啊! 在預設的情況下,每次更新程序資源的時間為 5 秒,不過,可以使用 -d 來進行修改。

    top 主要分為兩個畫面,上面的畫面為整個系統的資源使用狀態,基本上總共有六行, 顯示的內容依序是:

    第一行:顯示系統已啟動的時間、目前上線人數、系統整體的負載(load)。 比較需要注意的是系統的負載,三個數據分別代表 1, 5, 10 分鐘的平均負載。 一般來說,這個負載值應該不太可能超過 1 才對,除非您的系統很忙碌。 如果持續高於 5 的話,那麼.....仔細的看看到底是那個程序在影響整體系統吧!

    第二行:顯示的是目前的觀察程序數量,比較需要注意的是最後的 zombie 那個數值,如果不是 0 ,嘿嘿!好好看看到底是那個 process 變成疆屍了吧?!

    第三行:顯示的是 CPU 的整體負載,每個項目可使用 ? 查閱。需要觀察的是 id (idle) 的數值,一般來說,他應該要接近 100% 才好,表示系統很少資源被使用啊! ^_^。

    第四行與第五行:表示目前的實體記憶體與虛擬記憶體 (Mem/Swap) 的使用情況。

    第六行:這個是當在 top 程式當中輸入指令時,顯示狀態的地方。 例如範例四就是一個簡單的使用例子。

    至於 top 底下的畫面,則是每個 process 使用的資源情況。比較需要注意的是:

    PID :每個 process 的 ID 啦!

    USER:該 process 所屬的使用者;

    PR :Priority 的簡寫,程序的優先執行順序,越小越早被執行;

    NI :Nice 的簡寫,與 Priority 有關,也是越小越早被執行;

    %CPU:CPU 的使用率;

    %MEM:記憶體的使用率;

    TIME+:CPU 使用時間的累加;

    一般來說,如果鳥哥想要找出最損耗 CPU 資源的那個程序時,大多使用的就是 top 這支程式啦!然後強制以 CPU 使用資源來排序 (在 top 當中按下 P 即可), 就可以很快的知道啦!

    查看内存占用情况:

    #top -d 1 再输入:shift+m

  • 相关阅读:
    CentOS-6.8 最详细安装教程(贴镜像文件+多图)
    SSM 框架整合完整流程讲解(IDEA + Maven)
    【万字长文】Spring MVC 层层递进轻松入门 !
    Spring AOP 由浅入深学习教程【新手向】
    Spring 注解和XML两种方式配置IOC
    【万字长文】Spring框架 层层递进轻松入门 (IOC和DI)
    用idea搭建SSM项目,原来这么简单
    Java并发编程:什么是CAS?这回总算知道了
    Java并发编程:Java的四种线程池的使用,以及自定义线程工厂
    Java并发编程:Java线程池核心ThreadPoolExecutor的使用和原理分析
  • 原文地址:https://www.cnblogs.com/eagleking0318/p/6521501.html
Copyright © 2011-2022 走看看