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

img
我的圈子: 高级工程师聚集地
我是董哥,高级嵌入式软件开发工程师,从事嵌入式Linux驱动开发和系统开发,曾就职于世界500强公司!
创作理念:专注分享高质量嵌入式文章,让大家读有所得!
img

文章目录

    • 1、Top命令介绍
    • 2、Top命令使用
    • 3、Top信息详解
      • 3.1 概览区详解
      • 3.2 任务区
        • 3.2.1 任务字段介绍
        • 3.2.2 字段管理
    • 4、交互命令详解

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
欢迎关注 公号&星球【嵌入式艺术】,董哥原创!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/196272.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

初刷leetcode题目(3)——数据结构与算法

😶‍🌫️😶‍🌫️😶‍🌫️😶‍🌫️Take your time ! 😶‍🌫️😶‍🌫️😶‍🌫️😶‍🌫️…

JVM垃圾回收相关概念

目录 一、System.gc()的理解 二、内存溢出与内存泄露 (一)OOM (二)内存泄露 三、StopTheWorld 四、垃圾回收的并行与并发 五、安全点与安全区域 (一)安全点 (二)安全区域 …

迪克森电荷泵

迪克森电荷泵(Dickson Charge Pump)是一种电压倍增器电路,可以将低电压升高到较高电压,相对于其他电压升压电路,迪克森电荷泵具有较高的效率和较简单的电路结构。该电路的基本原理是通过电容和开关来实现电荷的积累和转…

Open AI开发者大会:AI“科技春晚”

ChatGPT的亮相即将满一年之时,OpenAI举行了自己的首次开发者大会。OpenAI首席执行官Sam Altman宣布推出最新的大模型GPT-4 Turbo。正如“Turbo”一词的中文含义“涡轮增压器”一样,本次发布会上,OpenAI的这款最新大模型在长文本、知识库、多模…

「Tech初见」对epoll的理解

一、Motivation 通常,操作系统会为每个进程划分一个时间片的,在这个时间片内进程可以合法占有 cpu 进行一些计算任务。并当时间片结束后自动退回至就绪状态待命,等待下一次的调度 但是,有一种情况会使进程提前(时间片…

数据结构 堆

手写堆&#xff0c;而非stl中的堆 如何手写一个堆&#xff1f; //将数组建成堆 <O(n) for (int i n / 2;i;i--) //从n/2开始down down(i); 从n/2元素开始down&#xff0c;最下面一层元素的个数是n/2&#xff0c;其余上面的元素的个数是n/2&#xff0c;从最下面一层到最高层…

【开源】基于Vue和SpringBoot的教学过程管理系统

项目编号&#xff1a; S 054 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S054&#xff0c;文末获取源码。} 项目编号&#xff1a;S054&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 教师端2.2 学生端2.3 微信小程序端2…

7 Redis的PipeLine

PipeLine的作用是批量执行命令 redis的性能瓶颈基本上是网络 import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.…

【Flink】核心概念:并行度与算子链

并行度&#xff08;Parallelism&#xff09; 当要处理的数据量非常大时&#xff0c;我们可以把一个算子操作&#xff0c;“复制”多份到多个节点&#xff0c;数据来了之后就可以到其中任意一个执行。这样一来&#xff0c;一个算子任务就被拆分成了多个并行的“子任务”&#x…

Python---return返回值

return返回值 返回值&#xff1a;很多函数在执行完毕后&#xff0c;会通过return关键字返回一个结果给 调用它的位置。 return 英 /rɪˈtɜːn/ n. 回来&#xff0c;返回&#xff1b; 思考&#xff1a;如果一个函数需要两个return (如下所示)&#xff0c;程序如何执行&…

Go语言常用命令详解(二)

文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…

滚雪球学Java(09-5):Java中的赋值运算符,你真的掌握了吗?

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴——bug菌&#xff0c;今天又来给大家普及Java SE相关知识点了&#xff0c;别躲起来啊&#xff0c;听我讲干货还不快点赞&#xff0c;赞多了我就有动力讲得更嗨啦&#xff01;所以呀&#xff0c;养成先点赞后阅读的好…