Linux中强大的top命令[通俗易懂]

Linux中强大的top命令

大家好,又见面了,我是全栈君。

top命令算是最直观、好用的查看服务器负载的命令了。它实时动态刷新显示服务器状态信息,且可以通过交互式命令自定义显示内容,非常强大。

在终端中输入top,回车后会显示如下内容:

  1.  
    top - 21:48:39 up 8:57, 2 users, load average: 0.36, 0.24, 0.14

  2.  
    Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie

  3.  
    %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

  4.  
    KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers

  5.  
    KiB Swap: 1046524 total, 280708 used, 765816 free. 365556 cached Mem

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

  8.  
    8096 root 20 0 320624 38508 21192 S 1.7 3.8 0:41.03 Xorg

  9.  
    13536 tabalt 20 0 697336 104272 56776 S 1.7 10.3 0:08.29 gnome-langu+

  10.  
    9426 tabalt 20 0 1213228 72976 16860 S 1.0 7.2 2:07.27 compiz

  11.  
    197 root 20 0 0 0 0 S 0.3 0.0 0:36.13 kworker/0:2

  12.  
    1009 root 20 0 303112 3392 1500 S 0.3 0.3 0:00.93 polkitd

  13.  
    9670 tabalt 20 0 325932 4300 2256 S 0.3 0.4 0:40.27 vmtoolsd

  14.  
    14016 root 25 5 43940 2408 2000 S 0.3 0.2 0:01.12 http

  15.  
    14149 tabalt 20 0 591180 19504 12820 S 0.3 1.9 0:00.45 gnome-termi+

  16.  
    1 root 20 0 33648 1972 744 S 0.0 0.2 0:01.79 init

  17.  
    2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd

  18.  
    3 root 20 0 0 0 0 S 0.0 0.0 0:02.80 ksoftirqd/0

  19.  
    4 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0

  20.  
    5 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0H

  21.  
    7 root 20 0 0 0 0 S 0.0 0.0 0:05.55 rcu_sched

  22.  
    8 root 20 0 0 0 0 R 0.0 0.0 0:03.43 rcuos/0

  23.  
    9 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/1

  24.  
    10 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/2

  25.  
     

一、系统信息统计

前五行是系统整体状态的统计信息展示区域。下面分别介绍每一行中的内容:

1、第一行显示服务器概况

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

  1.  
    top - 21:48:39 up 8:57, 2 users, load average: 0.36, 0.24, 0.14

  2.  
    / / / \

  3.  
    当前时间 运行时长 当前登录用户数 平均负载(1分钟、5分钟、15分钟)

  4.  
     

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

对于只有单核cpu的系统,1.0是该系统所能承受负荷的边界值,大于1.0则有处理需要等待。

一个单核cpu的系统,平均负载的合适值是0.7以下。如果负载长期徘徊在1.0,则需要考虑马上处理了。超过1.0的负载,可能会带来非常严重的后果。

当然,多核cpu的系统是在前述值的基础上乘以cpu内核的个数。如对于多核cpu的系统,有N个核则所能承受的边界值为N.0

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

cat /proc/cpuinfo 

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

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

2、第二行是进程信息:

  1.  
    Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie

  2.  
    / / / / /

  3.  
    进程总数 正运行进程数 睡眠进程数 停止进程数 僵尸进程数

3、第三行是CPU信息:

  1.  
    %Cpu(s):

  2.  
    5.0 us 用户空间CPU占比

  3.  
    1.7 sy 内核空间CPU占比

  4.  
    0.0 ni 用户进程空间改过优先级的进程CPU占比

  5.  
    93.0 id 空闲CPU占比

  6.  
    0.0 wa 待输入输出CPU占比

  7.  
    0.3 hi 硬中断(Hardware IRQ)CPU占比

  8.  
    0.0 si 软中断(Software Interrupts)CPU占比

  9.  
    0.0 st –

4、第四行是内存信息:

  1.  
    KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers

  2.  
    /
    / / /

  3.  
    物理内存总量 使用中总量 空闲总量 缓存的内存量

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

  1.  
    KiB Swap: 1046524 total, 280708 used, 765816 free, 365556 cached Mem

  2.  
    /
    / / /

  3.  
    交换区总量 使用中总量 空闲总量 缓存的内存量

二、进程(任务)状态监控

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

  1.  
    PID 进程id

  2.  
    USER 进程所有者

  3.  
    PR 进程优先级

  4.  
    NI nice值。负值表示高优先级,正值表示低优先级

  5.  
    VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

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

  7.  
    SHR 共享内存大小,单位kb

  8.  
    S 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程

  9.  
    %CPU 上次更新到现在的CPU时间占用百分比

  10.  
    %MEM 进程使用的物理内存百分比

  11.  
    TIME+ 进程使用的CPU时间总计,单位
    1/100秒

  12.  
    COMMAND 进程名称(命令名/命令行)

三、与top交互

  • 按键b打开或关闭 运行中进程的高亮效果

  • 按键x打开或关闭 排序列的高亮效果

  • shift + > 或 shift + < 可以向右或左改变排序列

  • f键,可以进入编辑要显示字段的视图,有 * 号的字段会显示,无 * 号不显示,可根据页面提示选择或取消字段。

  • https://blog.csdn.net/heybob/article/details/52032829
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112181.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月9日 下午1:00
下一篇 2022年2月9日 下午1:00


相关推荐

  • win10的pagefile.sys是什么文件?pagefile.sys文件太大如何移动到D盘中?

    win10的pagefile.sys是什么文件?pagefile.sys文件太大如何移动到D盘中?    在C盘系统下,有一个命名为pagefile.sys的文件占用C盘太大的空间,不少用户怕删除pagefile.sys文件之后会对系统造成影响,而不少用户想要将pagefile.sys文件移动到D盘中。那么pagefile.sys是什么文件?Win10系统下pagefile.sys文件太大如何移动到D盘中?pagefile.sys是什么文件?pagefile.sys文件是操作系…

    2022年7月25日
    38
  • Pycharm安装pip pip安装第三方模块

    Pycharm安装pip pip安装第三方模块Pycharm 安装 pippip 安装第三方组建打开 pycharm 文件 设置 项目 projectinter 点击 加号 在搜索栏中选择 pip 勾选红色框内 点击 installpacka 等待安装完成关闭 pycharm 重新打开模块就可以使用了 默认模块安装路径在 python 目录的 scrip

    2026年3月27日
    2
  • 什么是TLB ?

    什么是TLB ?TLB TranslationL 根据功能可以译为快表 直译可以翻译为旁路转换缓冲 也可以把它理解成页表缓冲 里面存放的是一些页表文件 虚拟地址到物理地址的转换表 当处理器要在主内存寻址时 不是直接在内存的物理地址里查找的 而是通过一组虚拟地址转换到主内存的物理地址 TLB 就是负责将虚拟内存地址翻译成实际的物理内存地址 而 CPU 寻址时会优先在 TLB 中进行寻址

    2026年3月16日
    2
  • linux recv返回值,recv recvfrom[通俗易懂]

    linux recv返回值,recv recvfrom[通俗易懂]recv和recvfrom都是用来接受来自的网络的数据。来看看它们的原型:intrecv(SOCKET,charFAR*,int,int);intrecvfrom(SOCKET,charFAR*,int,int,structsockaddrFAR*,intFAR*);这是在windows下面的定义。在linux下面的定义只是将SOCKET改成int,那么在linux下面的原型是这样:…

    2022年7月23日
    36
  • SFML初学-俄罗斯方块实现

    SFML初学-俄罗斯方块实现偶然看到大神使用 SFML 制作游戏 简单学习了一下这个库的使用并且仿照 YouTube 上大神的思路做了一个俄罗斯方块 目前只实现了出现方块 消除方块的功能 随着慢慢学习一点点继续修改吧 资源 源码 Copyr

    2026年3月18日
    2
  • 逻辑

    逻辑

    2022年1月13日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号