top命令应该怎么用?top命令里面参数都是什么

top命令经常用来监控Linux的系统状况,比如cpu、内存的使用,程序员基本都知道这个命令
1. 系统运行时间和平均负载
top命令的顶部显示与uptime命令的输出相似这些字段显示:

  • 当前时间
  • 系统已运行的时间
  • 当前登录用户的数量
  • 最近5、10和15分钟内的平均负载。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FES9RQTj-1591342615681)(en-resource://database/933:1)]

21:45:11 — 当前系统时间
0 days, 4:54 — 系统已经运行了4小时54分钟(在这期间没有重启过)
2 users — 当前有2个用户登录系统
load average:0.24, 0.15, 0.19 — load average后面的三个数分别是5分钟、10分钟、15分钟的负载情况。
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

执行 uptime 命令显示
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9M3JhR21-1591342615682)(en-resource://database/930:1)]

1.2 任务

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dze4BA5e-1591342615683)(en-resource://database/932:1)]

Tasks — 任务(进程),系统现在共有144个进程,其中处于运行中的有1个,143个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。
第二行显示的是任务或者进程的总结。进程可以处于不同的状态。这里显示了全部进程的数量。除此之外,还有正在运行、睡眠、停止、僵尸进程的数量(僵尸是一种进程的状态)。这些进程概括信息可以用't'切换显示

1.3 CPU 状态:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Xoke7cOb-1591342615686)(en-resource://database/931:1)]
这里显示不同模式下所占cpu时间百分比,这些不同的cpu时间表示:
可以使用't'命令切换显示。

  • 1.3% us — 用户空间占用CPU的百分比。
  • 1.0% sy — 内核空间占用CPU的百分比。
  • 0.0% ni — 改变过优先级的进程占用CPU的百分比
  • 97.3% id — 空闲CPU百分比
  • 0.0% wa — IO等待占用CPU的百分比
  • 0.3% hi — 硬中断(Hardware IRQ)占用CPU的百分比
  • 0.0% si — 软中断(Software Interrupts)占用CPU的百分比

在这里CPU的使用比率和windows概念不同,如果你不理解用户空间和内核空间,需要充充电了。

CPU利用率:CPU的使用情况。

显示名称详细解释
us用户时间(User time)表示CPU执行用户进程的时间,包括nices时间。通常期望用户空间CPU越高越好。
sy系统时间(System time)表示CPU在内核运行时间,包括IRQ和softirq时间。系统CPU占用率高,表明系统某部分存在瓶颈。通常值越低越好。
niNice时间(Nice time)系统调整进程优先级所花费的时间。
id空闲时间(Idle time)系统处于空闲期,等待进程运行。
wa等待时间(Waiting time)CPU在等待I/O操作完成所花费的时间。系统不应该花费大量时间来等待I/O操作,否则就说明I/O存在瓶颈。
hi硬中断处理时间(Hard Irq time)系统处理硬中断所花费的时间。
si软中断处理时间(SoftIrq time)系统处理软中断中断所花费的时间。
st丢失时间(Steal time)被强制等待(involuntary wait)虚拟CPU的时间,此时hypervisor在为另一个虚拟处理器服务。
  • us, user: 运行(未调整优先级的) 用户进程的CPU时间
  • sy,system: 运行内核进程的CPU时间
  • ni,niced:运行已调整优先级的用户进程的CPU时间
  • wa,IO wait: 用于等待IO完成的CPU时间
  • hi:处理硬件中断的CPU时间
  • si: 处理软件中断的CPU时间
  • st:这个虚拟机被hypervisor偷去的CPU时间(译注:如果当前处于一个hypervisor下的vm,实际上hypervisor也是要消耗一部分CPU处理时间的)。

CPU占用率计算:

Linux CPU占用率计算,都是根据/proc/stat文件内容计算而来。

$  more /proc/stat`

cpu 23977676 8265 27737139 5387873754 2095720 404 650273 0 0
cpu0 12075284 4247 13885851 2693786340 1054213 7 312015 0 0
cpu1 11902391 4018 13851287 2694087414 1041507 396 338257 0 0
intr 7878366837 118 6 0 0 0 0 0 0 0 0 0 31 104 0 0 69 0 0 0 0 0 0 0 0 0 24 0 29360958 0 23446119 0 798059818 13974 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
ctxt 51508933575
btime 1501052873
processes 17604072
procs_running 1
procs_blocked 0
softirq 6714836597 0 2060074967 76941 1854616421 18 0 2 584892288 14211110 2200964850

CPU信息,cpu为总的信息,cpu0 … cpun为各个具体CPU信息cpu 23977676 8265 27737139 5387873754 2095720 404 650273 0 0共有9个值(单位:ticks),分别为:ticks就是系统时钟中断的时间间隔,该值与内核中HZ值有关,即ticks = 1/HZ。HZ的值,就是每秒的时钟中断数量。可以观察/proc/interrupts中时钟中断值变化,来计算HZ的值。当HZ的值为1000时,ticks的单位即为1/1000秒,即1ms。User time:23977676 Nice time:8265 System time:27737139 Idle time:5387873754Waiting time:2095720 HardIrq time:404 SoftIRQ time:650273 Steal time:0 guest time:0

CPU占用率计算公式
CPU时间=user+system+nice+idle+iowait+irq+softirq+Stl +guest
%us=(User time + Nice time)/CPU时间100%
%sy=(System time + Hard Irq time +SoftIRQ time)/CPU时间
100%
%id=(Idle time)/CPU时间100%
%ni=(Nice time)/CPU时间
100% %wa=(Waiting time)/CPU时间100%
%hi=(Hard Irq time)/CPU时间
100%
%si=(SoftIRQ time)/CPU时间100%
%st=(Steal time)/CPU时间
100%CPU利用率总节:
(1)Linux CPU占用率是根据/proc/stat文件中的数据计算而来;
(2)/proc/stat中的数据精度为ticks,即1/HZ秒;
(3)内核每个ticks会更新一次CPU使用信息;
(4)CPU占用率的精度为1/HZ秒。

1.4 内存使用:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GpZpWggJ-1591342615689)(en-resource://database/935:1)]
接下来两行显示内存使用率,有点像'free'命令。第一行是物理内存使用,第二行是虚拟内存使用(交换空间)。物理内存显示如下:全部可用内存、已使用内存、空闲内存、缓冲内存。相似地:交换部分显示的是:全部、已使用、空闲和缓冲交换空间。
内存显示可以用m命令切换。
509248k total — 物理内存总量(509M)
495964k used — 使用中的内存总量(495M)
13284k free — 空闲内存总量(13M)
25364k buffers — 缓存的内存量 (25M)
swap交换分区
492536k total — 交换区总量(492M)
11856k used — 使用的交换区总量(11M)
480680k free — 空闲交换区总量(480M)
202224k cached — 缓冲的交换区总量(202M)

这里要说明的是不能用windows的内存概念理解这些数据,如果按windows的方式此台服务器“危矣”:8G的内存总量只剩下530M的可用内存。Linux的内存管理有其特殊性,复杂点需要一本书来说明,这里只是简单说点和我们传统概念(windows)的不同。

第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存:13284+25364+202224 = 240M。

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

1.5 各进程(任务)的状态监控:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FHXlCch2-1591342615690)(en-resource://database/934:1)]
PID:进程ID,进程的唯一标识符
USER:进程所有者的实际用户名。
PR:进程的调度优先级。这个字段的一些值是'rt'。这意味这这些进程运行在实时态。
NI:进程的nice值(优先级)。越小的值意味着越高的优先级。负值表示高优先级,正值表示低优先级
VIRT:进程使用的虚拟内存。进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
RES:驻留内存大小。驻留内存是任务使用的非交换物理内存大小。进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
SHR:SHR是进程使用的共享内存。共享内存大小,单位kb
S:这个是进程的状态。它有以下不同的值:

  • D - 不可中断的睡眠态。
  • R – 运行态
  • S – 睡眠态
  • T – 被跟踪或已停止
  • Z – 僵尸态
    %CPU:自从上一次更新时到现在任务所使用的CPU时间百分比。
    %MEM:进程使用的可用物理内存百分比。
    TIME+:任务启动后到现在所使用的全部CPU时间,精确到百分之一秒。
    COMMAND:运行进程所使用的命令。进程名称(命令名/命令行)
  • 参考文献
  • https://www.cnblogs.com/mushang1hao/p/10767062.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喜马拉雅以南

奶茶,干杯?!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值