linux top命令的使用

一、概念

Linux系统中,Top命令主要用于实时运行系统的监控,包括Linux内核管理的进程或者线程的资源占用情况。这个命令对所有正在运行的进程和系统负荷提供不断更新的概览信息,包括系统负载、CPU利用分布情况、内存使用、每个进程的内容使用情况等信息。

二、语法

op [-] [d delay] [q] [c] [S] [s] [i] [n] [b]

-d <秒数>:指定 top 命令的刷新时间间隔,单位为秒。

-n <次数>:指定 top 命令运行的次数后自动退出。

-p <进程ID>:仅显示指定进程ID的信息。

-u <用户名>:仅显示指定用户名的进程信息。

-H:显示线程信息,显示每个进程的线程信息。如 top -Hp pid : 显示进程 pid下的所有线程信息。

-i:不显示闲置(idle)或无用的进程。

-b:以批处理(batch)模式运行,直接将结果输出到文件。

-c:显示完整的命令行而不截断。

-S:累计显示进程的 CPU 使用时间。

top交互命令 在top命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了-s选项, 其中一些命令可能会被屏蔽。

h:显示帮助画面,给出一些简短的命令总结说明;

k:终止一个进程;

i:忽略闲置和僵死进程,这是一个开关式命令;

q:退出程序;

r:重新安排一个进程的优先级别;

S:切换到累计模式;

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

f或者F:从当前显示中添加或者删除项目;

o或者O:改变显示项目的顺序;

l:切换显示平均负载和启动时间信息;

m:切换显示内存信息;

t:切换显示进程和CPU状态信息;

c:切换显示命令名称和完整命令行;

w:将当前设置写入~/.toprc文件中。

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

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

T:根据时间/累计时间进行排序;E: 切换单位为 MiB、GiB、TiB、PiB、EiB,默认单位是KiB。

三、top命令说明

[sa@shwgq-t-tomcat-188-193 ~]$ top

top - 16:07:37 up 241 days, 20:11, 1 user, load average: 0.96, 1.13, 1.25

Tasks: 231 total, 1 running, 230 sleeping, 0 stopped, 0 zombie

Cpu(s): 12.7%us, 8.4%sy, 0.0%ni, 77.1%id, 0.0%wa, 0.0%hi, 1.8%si, 0.0%st

Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers

Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached

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

18411 pplive 20 0 11.9g 7.8g 5372 S 220.2 67.1 16761:00 java

1875 pplive 20 0 3958m 127m 4564 S 4.6 1.1 12497:35 java

4 root 20 0 0 0 0 S 0.3 0.0 184:01.76 ksoftirqd/0

13 root 20 0 0 0 0 S 0.3 0.0 135:49.83 ksoftirqd/2

25 root 20 0 0 0 0 S 0.3 0.0 136:54.49 ksoftirqd/5

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

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

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

统计信息说明:

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

第1段:系统当前时间,例如:16:07:37

第2段:系统运行时间,未重启的时间,时间越长系统越稳定。

格式:up xx days, HH:MM

例如:241 days, 20:11, 表示连续运行了241天20小时11分钟

第3段:当前登录用户数,例如:1 user,表示当前只有1个用户登录

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

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

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

第2行:Tasks 进程相关信息

第1段:进程总数,例如:Tasks: 231 total, 表示总共运行231个进程

第2段:正在运行的进程数,例如:1 running,

第3段:睡眠的进程数,例如:230 sleeping,

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

第5段:僵尸进程数,例如:0 zombie

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

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

第2段:sy 内核空间占用CPU百分比,例如:8.4%sy,

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

第4段:id 空闲CPU百分比,例如:77.1%id,

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

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

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

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

第4行:Mem 内存相关信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)

第1段:物理内存总量,例如:Mem: 12196436k total,

第2段:使用的物理内存总量,例如:12056552k used,

第3段:空闲内存总量,例如:Mem: 139884k free,

第4段:用作内核缓存的内存量,例如:64564k buffers

第5行:Swap 交换分区相关信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)

第1段:交换区总量,例如:Swap: 2097144k total,

第2段:使用的交换区总量,例如:151016k used,

第3段:空闲交换区总量,例如:1946128k free,

第4段:缓冲的交换区总量,3120236k cached

进程信息:

详细见:https://blog.csdn.net/yexiangCSDN/article/details/80797933

四、其他

监控java线程数:ps -eLf | grep java | wc -l

监控网络客户连接数:netstat -n | grep tcp | grep 侦听端口 | wc -l

参考:

https://blog.csdn.net/yexiangCSDN/article/details/80797933

https://blog.csdn.net/dong__ge/article/details/134496507

https://blog.csdn.net/u011939453/article/details/124515892