百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

top命令

liuian 2025-03-03 19:21 11 浏览

top命令是linux下常用的性能分析工具,能够实时的显示系统中各个进程的资源占用情况,常用于服务端性能分析。

top命令说明:

top命令的结果分为两部分:


统计信息:前五行是系统的整体统计信息。

进程信息:统计信息下方类似表格的区域显示的是进程的详细信息,默认5秒刷新一次。



统计信息说明:

第1行:top任务队列信息(系统运行状态及平均负载),与uptime命令结果相同。

第一段:系统当前时间,例如:10:57:04

第二段:系统运行时间,未重启的时间,时间越长系统越稳定。例如:up 778 days, 17:53;格式:up xx days, HH:mm

第三段:登录用户数,例如:3 users,表示当前有3个用户登录。

第四段:系统负载,即任务队列的平均长度,3个数值分别统计最近1、5、15分钟的系统平均负载。

系统平均负载:单核CPU情况下,0.00表示没有任何负载,1.00表示刚好满负荷,超过1表示超负 荷,理想值是0.7。

多核CPU负载:CPU核数*0.7理想值=理想负荷,例如:8核CPU负载不超过5.6表示没有出现高负 载。

第2行:Tasks任务进程相关信息

第一段:进程总数,405 total表示总共运行405个进程。

第二段:正在运行的进程数,例如:1 running表示有一个正在运行的进程。

第三段:正在睡眠的进程数,例如:404 sleeping。

第四段:停止的进程数,例如:0 stopped。

第五段:僵尸进程数,例如:0 zombile。

第3行:CPU相关信息,如果是多核CPU,按数字1可以显示多核CPU信息,此时第一段将转换为CPU核数,数字1可以来回切换。

第一段:us用户空间占用CPU百分比,例如:Cpu(s):5.8%us。

第二段:sy内核空间占用CPU百分比,例如:1.2%sy。

第三段:ni用户进程空间内改变过优先级的进程占用的百分比,例如:0.00%ni。

第四段:id空闲CPU百分比,例如:94.2%id。

第五段:wa等待输入输出的CPU时间百分比,例如:0.00%wa。

第六段:hi CPU服务于硬件中断所耗费的时间总额,例如:0.0%hi。

第七段:si CPU服务软中断所耗费的时间总额,例如:0.0%si。

第八段:st Steal time 虚拟机被hypervisor偷去的CPU时间(如果当前处于一个hypervisor下的vm,实际上 hypervisor也是要消耗一部分CPU处理时间的)。

第4行:Mem 内存相关信息(Mem: 32815228k total, 32146340k used, 668888k free, 73948k buffers)

第一段:物理内存总量,例如: 32815228k total。

第二段:使用的物理内存总量,例如:Mem: 32815228k total。

第三段:空闲内存总量,例如:668888k free。

第四段:用作内核缓存的内存量,例如:73948k buffers。

第5行:Swap 交换分区相关信息(Swap: 8524272k total, 7075992k used, 1448280k free, 7757408k cached)

第一段:交换区总量,例如:Swap: 8524272k total。

第二段:使用交换区总量,例如:7075992k used。

第三段:空闲交换区总量,例如:1448280k free。

第四段:缓冲的交换区总量,例如: 7757408k cached。


进程信息说明:

在top命令中按f可以查看显示的列信息,按对应的字母来开启或者关闭列,大写字母表示开启,小写字母表示关闭,带*号的标识默认列。

* A: PID = Process Id(进程ID)

* E: USER = User Name(进程所有者的用户名)

* H: PR = Priority(优先级)

* I: NI = Nice value(nice值,负值表示高优先级,正值表示低优先级)

* O: VIRT = Virtual Image (kb)(进程使用的虚拟内存总量,单位kb,VIRT=SWAP+RES)

* Q: RES = Resident size (kb)(进程使用的,未被换出的物理内存大小,单位kb,RES=CODE+DATA)

* T: SHR = Shared Mem size (kb)(共享内存大小,单位kb)

* W: S = Process Status(进程状态,D=不可终端的进程状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸 进程)

* K: %CPU = CPU usage(上次更新到现在的CPU时间占用百分比)

* N: %MEM = Memory usage (RES)(进程使用的物理内存占用百分比)

* M: TIME+ = CPU Time, hundredths(进程使用的CPU时间占比,单位1/100秒)

b: PPID = Parent Process Pid(父进程ID)

c: RUSER = Real user name

d: UID = User Id(进程的所有者的用户ID)

f: GROUP = Group Name(进程所有者的组名)

g: TTY = Controlling Tty(启动进程的终端名,不是从终端启动的进程则显示为?)

j: P = Last used cpu (SMP)(最后使用的CPU,仅在多CPU环境下有意义)

p: SWAP = Swapped size (kb)(进程使用的虚拟内存中,被换出的大小,单位kb)

l: TIME = CPU Time(进程使用的CPU时间总计,单位秒)

r: CODE = Code size (kb)(可执行代码占用物理内存大小,单位kb)

s: DATA = Data+Stack size (kb)(可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb)

u: nFLT = Page Fault count(页面错误次数)

v: nDRT = Dirty Pages count(最后一次写入到现在,被修改过的页面数)

y: WCHAN = Sleeping in Function(若该进程在睡眠,则显示睡眠中的系统函数名)

z: Flags = Task Flags (任务标志)

* X: COMMAND = Command name/line(命令名/命令行)


top命令选项

-b:以批处理模式操作;

-c:显示完整的治命令;

-d:屏幕刷新间隔时间;

-I:忽略失效过程;

-s:保密模式;

-S:累积模式;

-i<时间>:设置间隔时间;

-u<用户名>:指定用户名;

-p<进程号>:指定进程;

-n<次数>:循环显示的次数。


top命令交互

常用交互操作

基础操作

1:显示CPU详细信息,每核显示一行

d / s :修改刷新频率,单位为秒

h:可显示帮助界面

n:指定进程列表显示行数,默认为满屏行数

q:退出top

面板隐藏显示

l:隐藏/显示第1行负载信息;

t:隐藏/显示第2~3行CPU信息;

m:隐藏/显示第4~5行内存信息;

进程列表排序

M:根据驻留内存大小进行排序;

P:根据CPU使用百分比大小进行排序;

T:根据时间/累计时间进行排序;

详细交互指令:h / ? 可显示帮助界面,原始为英文版,简单翻译如下:

Help for Interactive Commands - procps version 3.2.8

Window 1:Def: Cumulative mode Off. System: Delay 3.0 secs; Secure mode Off.

Z,B Global: 'Z' change color mappings; 'B' disable/enable bold

Z:修改颜色配置;B:关闭/开启粗体

l,t,m Toggle Summaries: 'l' load avg; 't' task/cpu stats; 'm' mem info

l:隐藏/显示第1行负载信息;t:隐藏/显示第2~3行CPU信息;m:隐藏/显示第4~5行内存信息;

1,I Toggle SMP view: '1' single/separate states; 'I' Irix/Solaris mode

1:单行/多行显示CPU信息;I:Irix/Solaris模式切换

f,o . Fields/Columns: 'f' add or remove; 'o' change display order

f:列显示控制;o:列排序控制,按字母进行调整

F or O . Select sort field 选择排序列

<,> . Move sort field: '<' next col left; '>' next col right 上下移动内容

R,H . Toggle: 'R' normal/reverse sort; 'H' show threads

R:内容排序;H:显示线程

c,i,S . Toggle: 'c' cmd name/line; 'i' idle tasks; 'S' cumulative time

c:COMMAND列命令名称与完整命令行路径切换;i:忽略闲置和僵死进程开关;S:累计模式切换

x,y . Toggle highlights: 'x' sort field; 'y' running tasks

x:列排序;y:运行任务

z,b . Toggle: 'z' color/mono; 'b' bold/reverse (only if 'x' or 'y')

z:颜色模式;b:粗体开关 仅适用于x,y模式中

u . Show specific user only 按用户进行过滤,当输入错误可按Ctrl + Backspace进行删除

n or # . Set maximum tasks displayed 设置进程最大显示条数

k,r Manipulate tasks: 'k' kill; 'r' renice

k:终止一个进程;r:重新设置一个进程的优先级别

d or s Set update interval 改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成ms。输入0值则系统将不断刷新,默认值是5s;

W Write configuration file 将当前设置写入~/.toprc文件中

q Quit 退出

( commands shown with '.' require a visible task display window )

注意:带.的命令需要一个可见的任务显示窗口

Press 'h' or '?' for help with Windows, any other key to continue

————————————————

版权声明:本文为CSDN博主「OceanSky6」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:
https://blog.csdn.net/yaomingyang/article/details/78968573

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...