Linux性能分析——TOP命令详解

1、Top命令介绍

Linux系统中,Top命令主要用于实时运行系统的监控,包括Linux内核管理的进程或者线程的资源占用情况。

这个命令对所有正在运行的进程和系统负荷提供不断更新的概览信息,包括系统负载、CPU利用分布情况、内存使用、每个进程的内容使用情况等信息。

2、Top命令使用

Top的命令介绍如下

top -hv|-bcHiOSs -d secs -n max -u|U user -p pid -o fld -w [cols]

常用的Top指令有

top:启动top命令
top -c:显示完整的命令行
top -b:以批处理模式显示程序信息
top -S:以累积模式显示程序信息
top -n 2:表示更新两次后终止更新显示
top -d 3:设置信息更新周期为3秒
top -p 139:显示进程号为139的进程信息,CPU、内存占用率等
top -n 10:显示更新十次后退出

除此之外,在top进程运行过程中,两个最重要的功能是查看帮助(h)和退出(qCtrl+C)。

3、Top信息详解

top展示界面由从上到下3部分组成

  1. 概览区域
  2. 表头
  3. 任务区域
  4. 还有一个输入/消息行,位于概览区域和表头之间。

image-20230811143742616

3.1 概览区详解

top - 14:46:08 up  5:46,  1 user,  load average: 0.00, 0.00, 0.00
  • 程序或者窗口的名称:top
  • 当前时间和系统的启动时间:14:46:08 up 5:46
  • 总共的用户数量:1 user
  • 过去1、5和15分钟的系统平均负载:load average: 0.00, 0.00, 0.00
Tasks: 290 total,   1 running, 212 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.1 sy,  0.0 ni, 99.9 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st

这两行显示了任务数量和CPU状态

  • 第一行该信息对Task进行分类,包括runningsleepingstoppedzombie四类,显示了系统中正在运行的任务的状态统计信息。具体来说,这里有291个任务总数,其中有1个任务正在运行,212个任务正在睡眠,0个任务已停止,0个任务为僵尸进程。
  • 第二行显示CPU的状态百分比
    • %Cpu(s): CPU使用率的统计信息。
    • us (user): 用户空间进程占用CPU的时间百分比。
    • sy (system): 内核空间进程占用CPU的时间百分比。
    • ni (nice): 用户进程以优先级调整过的占用CPU的时间百分比(通常不会有这个值)。
    • id (idle): CPU空闲的时间百分比。
    • wa (IO-wait): CPU等待I/O操作的时间百分比。
    • hi (hardware interrupt): CPU处理硬件中断的时间百分比。
    • si (software interrupt): CPU处理软件中断的时间百分比。
    • st: 被虚拟化环境偷取的时间百分比(通常不会有这个值)。
KiB Mem :  3994720 total,   525876 free,   595492 used,  2873352 buff/cache
KiB Swap:  2097148 total,  2096624 free,      524 used.  3114400 avail Mem

这两行表示内存的使用情况

  • 第一行表示物理内存,分为totalfreeusedbuff/cache
  • 第二行表示虚拟内存,分为totalfreeusedavail

默认单位是KiB,使用按键E可以切换为MiBGiBTiBPiBEiB

KiB = kibibyte = 1024 bytes
MiB = mebibyte = 1024 KiB = 1,048,576 bytes
GiB = gibibyte = 1024 MiB = 1,073,741,824 bytes
TiB = tebibyte = 1024 GiB = 1,099,511,627,776 bytes
PiB = pebibyte = 1024 TiB = 1,125,899,906,842,624 bytes
EiB = exbibyte = 1024 PiB = 1,152,921,504,606,846,976 bytes

更多干货可见:高级工程师聚集地,助力大家更上一层楼!

3.2 任务区

任务区是按照列的形式来显示的,并且有多个字段可以用来查看进程的状态信息。

3.2.1 任务字段介绍

  • %CPUCPU Usage,自上次屏幕更新以来任务占用的CPU时间份额,表示为总CPU时间的百分比。

  • %MEMMemory Usage,进程使用的物理内存百分比

  • CODECode Size,可执行代码占用的物理内存量

  • COMMANDCommand Name or Command Line,用于显示输入的命令行或者程序名称

  • PIDProcess Id,任务独立的ID,即进程ID

  • PPIDParent Process Id,父进程ID

  • UIDUser Id,任务所有者的用户ID

  • USERUser Name,用户名

  • RUSERReal User Name,实际的用户名

  • TTYControlling Tty,控制终端名称

  • TIMECPU TIME,该任务CPU总共运行的时间

  • TIME+:同TIME,其粒度更细

  • OOMaOut of Memory Adjustment Factor,内存溢出调整机制,这个字段会被增加到当前内存溢出分数中,来决定什么任务会被杀掉,范围是-1000到+1000。

  • OOMsOut of Memory Score,内存溢出分数,这个字段是用来选择当内存耗尽时杀掉的任务,范围是0到+1000。0的意思是绝不杀掉,1000的意思是总是杀掉。

  • SProcess Status,表示进程状态信息

    • D: 不可中断休眠
    • I:空闲
    • R:运行中
    • S:休眠
    • T:被任务控制信号停止
    • t:在跟踪期间被调试器停止
    • Z:僵尸

相关属性有很多,可以使用man top查看,这里先列举这些。

3.2.2 字段管理

我们输入top后,默认只显示一部分属性信息,我们可以自行管理想要的属性信息。

我们输入F或者f,进入字段管理功能,用于选择想要的字段信息

按键 功能
光标上下移动选择
空格d 切换
s 设置为排序依据字段
aw 在4种窗口中切换:1.默认,2.任务,3.内存,4.用户
Esc键q 退出当前窗口

4、交互命令详解

top的功能很多,基本能够查看进程的各种状态信息,其中还有一些交互式的命令,方便我们更好的查看系统状态。

top主界面中,我们输入下面的命令

命令 功能
h? 帮助信息查看,涵盖所有的快捷键
空格、回车按键 手动刷新界面信息
qESC按键 退出
B 粗体显示功能
ds 改变间隔时间
Ee 切换内存显示的单位,从KiBEiB
g 然后输入1-4其中一个数字,选择哪种窗口(1.默认,2.任务,3.内存,4.用户)
H 进程、线程显示切换
k 输入PID信息,杀掉一个任务
Z 改变配色

上面介绍了一些比较常见的交互式命令,还有更多需要你去探索哦!

Linux性能分析——TOP命令详解

1、Top命令介绍

Linux系统中,Top命令主要用于实时运行系统的监控,包括Linux内核管理的进程或者线程的资源占用情况。

这个命令对所有正在运行的进程和系统负荷提供不断更新的概览信息,包括系统负载、CPU利用分布情况、内存使用、每个进程的内容使用情况等信息。

2、Top命令使用

Top的命令介绍如下

top -hv|-bcHiOSs -d secs -n max -u|U user -p pid -o fld -w [cols]

常用的Top指令有

top:启动top命令
top -c:显示完整的命令行
top -b:以批处理模式显示程序信息
top -S:以累积模式显示程序信息
top -n 2:表示更新两次后终止更新显示
top -d 3:设置信息更新周期为3秒
top -p 139:显示进程号为139的进程信息,CPU、内存占用率等
top -n 10:显示更新十次后退出

除此之外,在top进程运行过程中,两个最重要的功能是查看帮助(h)和退出(qCtrl+C)。

3、Top信息详解

top展示界面由从上到下3部分组成

  1. 概览区域
  2. 表头
  3. 任务区域
  4. 还有一个输入/消息行,位于概览区域和表头之间。

image-20230811143742616

3.1 概览区详解

top - 14:46:08 up  5:46,  1 user,  load average: 0.00, 0.00, 0.00
  • 程序或者窗口的名称:top
  • 当前时间和系统的启动时间:14:46:08 up 5:46
  • 总共的用户数量:1 user
  • 过去1、5和15分钟的系统平均负载:load average: 0.00, 0.00, 0.00
Tasks: 290 total,   1 running, 212 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.1 sy,  0.0 ni, 99.9 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st

这两行显示了任务数量和CPU状态

  • 第一行该信息对Task进行分类,包括runningsleepingstoppedzombie四类,显示了系统中正在运行的任务的状态统计信息。具体来说,这里有291个任务总数,其中有1个任务正在运行,212个任务正在睡眠,0个任务已停止,0个任务为僵尸进程。
  • 第二行显示CPU的状态百分比
    • %Cpu(s): CPU使用率的统计信息。
    • us (user): 用户空间进程占用CPU的时间百分比。
    • sy (system): 内核空间进程占用CPU的时间百分比。
    • ni (nice): 用户进程以优先级调整过的占用CPU的时间百分比(通常不会有这个值)。
    • id (idle): CPU空闲的时间百分比。
    • wa (IO-wait): CPU等待I/O操作的时间百分比。
    • hi (hardware interrupt): CPU处理硬件中断的时间百分比。
    • si (software interrupt): CPU处理软件中断的时间百分比。
    • st: 被虚拟化环境偷取的时间百分比(通常不会有这个值)。
KiB Mem :  3994720 total,   525876 free,   595492 used,  2873352 buff/cache
KiB Swap:  2097148 total,  2096624 free,      524 used.  3114400 avail Mem

这两行表示内存的使用情况

  • 第一行表示物理内存,分为totalfreeusedbuff/cache
  • 第二行表示虚拟内存,分为totalfreeusedavail

默认单位是KiB,使用按键E可以切换为MiBGiBTiBPiBEiB

KiB = kibibyte = 1024 bytes
MiB = mebibyte = 1024 KiB = 1,048,576 bytes
GiB = gibibyte = 1024 MiB = 1,073,741,824 bytes
TiB = tebibyte = 1024 GiB = 1,099,511,627,776 bytes
PiB = pebibyte = 1024 TiB = 1,125,899,906,842,624 bytes
EiB = exbibyte = 1024 PiB = 1,152,921,504,606,846,976 bytes

更多干货可见:高级工程师聚集地,助力大家更上一层楼!

3.2 任务区

任务区是按照列的形式来显示的,并且有多个字段可以用来查看进程的状态信息。

3.2.1 任务字段介绍

  • %CPUCPU Usage,自上次屏幕更新以来任务占用的CPU时间份额,表示为总CPU时间的百分比。

  • %MEMMemory Usage,进程使用的物理内存百分比

  • CODECode Size,可执行代码占用的物理内存量

  • COMMANDCommand Name or Command Line,用于显示输入的命令行或者程序名称

  • PIDProcess Id,任务独立的ID,即进程ID

  • PPIDParent Process Id,父进程ID

  • UIDUser Id,任务所有者的用户ID

  • USERUser Name,用户名

  • RUSERReal User Name,实际的用户名

  • TTYControlling Tty,控制终端名称

  • TIMECPU TIME,该任务CPU总共运行的时间

  • TIME+:同TIME,其粒度更细

  • OOMaOut of Memory Adjustment Factor,内存溢出调整机制,这个字段会被增加到当前内存溢出分数中,来决定什么任务会被杀掉,范围是-1000到+1000。

  • OOMsOut of Memory Score,内存溢出分数,这个字段是用来选择当内存耗尽时杀掉的任务,范围是0到+1000。0的意思是绝不杀掉,1000的意思是总是杀掉。

  • SProcess Status,表示进程状态信息

    • D: 不可中断休眠
    • I:空闲
    • R:运行中
    • S:休眠
    • T:被任务控制信号停止
    • t:在跟踪期间被调试器停止
    • Z:僵尸

相关属性有很多,可以使用man top查看,这里先列举这些。

3.2.2 字段管理

我们输入top后,默认只显示一部分属性信息,我们可以自行管理想要的属性信息。

我们输入F或者f,进入字段管理功能,用于选择想要的字段信息

按键 功能
光标上下移动选择
空格d 切换
s 设置为排序依据字段
aw 在4种窗口中切换:1.默认,2.任务,3.内存,4.用户
Esc键q 退出当前窗口

4、交互命令详解

top的功能很多,基本能够查看进程的各种状态信息,其中还有一些交互式的命令,方便我们更好的查看系统状态。

top主界面中,我们输入下面的命令

命令 功能
h? 帮助信息查看,涵盖所有的快捷键
空格、回车按键 手动刷新界面信息
qESC按键 退出
B 粗体显示功能
ds 改变间隔时间
Ee 切换内存显示的单位,从KiBEiB
g 然后输入1-4其中一个数字,选择哪种窗口(1.默认,2.任务,3.内存,4.用户)
H 进程、线程显示切换
k 输入PID信息,杀掉一个任务
Z 改变配色

上面介绍了一些比较常见的交互式命令,还有更多需要你去探索哦!

img

Linux性能分析——TOP命令详解的更多相关文章

  1. Linux下top命令详解

    Linux下top命令详解 top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.top是一个动态显示过程,即可以通过用户按键来不断刷 ...

  2. Linux上的free命令详解、swap机制

    Linux上的free命令详解   解释一下Linux上free命令的输出. 下面是free的运行结果,一共有4行.为了方便说明,我加上了列号.这样可以把free的输出看成一个二维数组FO(Free ...

  3. LINUX经常使用的命令详解

    LINUX经常使用的命令详解 源地址:http://blog.itpub.net/29065182/viewspace-1189162/ 1.man 对你熟悉或不熟悉的命令提供帮助解释  eg:man ...

  4. Top 命令详解

    Top 命令详解 先感受一下top命令的执行结果吧!哈哈-- top - 17:32:34 up 3 days, 8:04, 5 users, load average: 0.09, 0.12, 0. ...

  5. Linux CAT与ECHO命令详解 <<EOF EOF

    Linux CAT与ECHO命令详解 cat命令是Linux下的一个文本输出命令,通常是用于观看某个文件的内容的: cat主要有三大功能: .一次显示整个文件. $ cat filename .从键盘 ...

  6. [r]Ubuntu Linux系统下apt-get命令详解

    Ubuntu Linux系统下apt-get命令详解(via|via) 常用的APT命令参数: apt-cache search package 搜索包 apt-cache show package ...

  7. Linux CAT与ECHO命令详解

    Linux CAT与ECHO命令详解 cat命令是Linux下的一个文本输出命令,通常是用于观看某个文件的内容的: cat主要有三大功能: 1.一次显示整个文件. $ cat filename 2.从 ...

  8. (转)Linux: dirname、basename命令详解

    Linux: dirname.basename命令详解 原文:http://blog.sina.com.cn/s/blog_3f63916f010143vo.html 一.dirname指令 1.功能 ...

  9. Linux 性能分析 工具命令

    背景知识:具备背景知识是分析性能问题时需要了解的.比如硬件 cache:再比如操作系统内核.应用程序的行为细节往往是和这些东西互相牵扯的,这些底层的东西会以意想不到的方式影响应用程序的性能,比如某些程 ...

  10. Linux下面的yum命令详解

    yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...

随机推荐

  1. 超轻量级MP4封装方法介绍

    liwen01 2023.12.17 前言 MP4是目前非常常用的一种视频封装格式,关于MP4的介绍资料也非常多.我们常用的封装库或工具有:ffmpeg,libmp4v2,GPAC,MP4.js,它们 ...

  2. 在IDEA启动多个Spring Boot工程实例

    在IDEA上点击Application右边的下三角 ,弹出选项后,点击Edit Configuration 选中需要多实例启动的应用,将默认的Single instance only(单实例)的钩去掉 ...

  3. UDP与KCP详解

    UDP 以及TCP是什么.我们知道传输层中有TCP和UDP两种网络协议,这节就讲UDP是什么. Internet协议集支持一个无连接的传输协议,该协议称为用户数据报协议(UDP,User Datagr ...

  4. GOF23--23种设计模式(三)

    一.桥接模式 Java中的桥接模式(Bridge Pattern)是一种结构性设计模式,它将抽象部分和实现部分分离,使它们可以独立变化,同时通过桥接对象将它们连接起来. 这种模式将抽象与其实现解耦,使 ...

  5. 大道如青天,协程来通信,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang通道channel的使用EP14

    众所周知,Go lang的作用域相对严格,数据之间的通信往往要依靠参数的传递,但如果想在多个协程任务中间做数据通信,就需要通道(channel)的参与,我们可以把数据封装成一个对象,然后把这个对象的指 ...

  6. 解析Stream foreach源码

    摘要:串行流比较简单,对于parallelStream,站在它背后的是ForkJoin框架. 本文分享自华为云社区<深入理解Stream之foreach源码解析>,作者:李哥技术 . 前言 ...

  7. 为啥你写的代码老有大串的if/else?

    摘要:控制语句,到底何错之有呢? 本文分享自华为云社区<业务代码如何才能不再写出大串的if/else?>,作者: JavaEdge . 控制结构?没错!你最爱的 if.for都是一类坏味道 ...

  8. OGC标准WMTS服务概念与地图商的瓦片编号流派-web地图切片加载

    还不知道地图栅格化切片等相关GIS原理的,推荐阅读<webGIS底图栅格化与实时数据合成处理原理,地图API设计,xyz加载> OGC概念 OGC全称--开放地理空间信息联盟(Open G ...

  9. 火山引擎 DataTester 上线“流程画布”功能,支持组合型 A/B 实验分析

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 在精细化运营的时代,运营活动同样需要有精细化的策略,例如在年末大促活动中,设计 APP 弹窗提醒.满减.会员领券时 ...

  10. Solon2 开发之IoC,一、注入或手动获取配置

    约定 resources/app.yml( 或 app.properties ) #为应用配置文件 配置样例 track: name: xxx url: http://a.a.a db1: jdbcU ...