这是一张top的图
第一行
字符 | 含义 |
---|---|
top - 10:03:19 | 当前系统时间 |
up 137 days , 10:40 | 系统已运行时间,系统已经运行了137天10小时40分钟(在这期间系统没有重启过的吆!) |
2 user | 在线用户,当前有2个用户登录系统,包含系统用户。 |
load average: 0.00, 0.01, 0.05 | 系统负载。load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。 |
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了
第二行
Tasks — 任务(进程),具体信息说明如下:
字符 | 含义 |
---|---|
Tasks : 92 total | 总进程数 |
2 running | 正在运行的进程数 |
90 sleeping | 正在睡眠的进程数 |
0 stopped | 停止的进程数 |
0 zombie | 僵尸进程数 |
僵尸进程:一个子进程在其父进程没有调用wait()或waitpid()的情况下退出。这个子进程就是僵尸进程。如果其父进程还存在而一直不调用wait,则该僵尸进程将无法回收,等到其父进程退出后该进程将被init回收。
第三行
cpu的使用情况
字符 | 含义 |
---|---|
0.3 us | 用户进程(用户空间)占用cpu百分率 |
0.3 sy | 系统(内核)占用cpu百分率 |
0.0 ni | 用户进程空间内改变过优先级的进程占用CPU百分比 |
99.3 id | cpu空闲率 |
0.0 wa | 等待IO的CPU时间百分比 |
0.0 hi | 硬中断(Hardware IRQ)占用CPU的百分比 |
0.0 si | 软中断(Software Interrupts)占用CPU的百分比 |
第四行
内存状态,具体信息如下:
字符 | 含义 |
---|---|
1016916 total | 内存总量(我这里是1G) |
82280 free | 内存空闲量 |
233848 used | 内存使用量 |
700788 buff/cache | 缓存的内存量 |
使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。
如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,
对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
第五行
swap交换分区信息,具体信息说明如下:
字符 | 含义 |
---|---|
KiB Swap: 0 total | 交换区总量 |
0 free | 交换区空闲量 |
0 used | 交换区使用量 |
第六行
各进程(任务)的状态监控,项目列信息说明如下:
字符 | 含义 |
---|---|
PID | 进程号 |
USER | 进程创建者 |
PR | 进程优先级 |
NI | nice值。越小优先级越高,最小-20,最大20(用户设置最大19) |
VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |
RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |
SHR | 共享内存大小,单位kb |
S | 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程 |
%CPU | 进程占用cpu百分比 |
%MEM | 进程占用内存百分比 |
TIME+ | 进程运行时间 |
COMMAND | 进程名称 |
PR 越低优先级 越高,PRI(new)=PRI(old)+nice
PR中的rt为实时进程优先级即rt_priority,prio=MAX_RT_PRIO - 1- p->rt_priority
MAX_RT_PRIO = 99,prio大小决定最终优先级。这样意味着rt_priority值越大,优先级越高而内核提供的修改优先级的函数,是修改rt_priority的值,所以越大,优先级越高。
例:改变优先级:进入top后按“r”–>输入进程PID–>输入nice值
其他技巧
1.多U多核CPU监控
在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况:
观察上图,服务器有16个逻辑CPU,实际上是4个物理CPU。再按数字键1,就会返回到top基本视图界面。
2.高亮显示当前运行进程
敲击键盘“b”(打开/关闭加亮效果),top的视图变化如下:
我们发现进程id为2570的“top”进程被加亮了,top进程就是视图第二行显示的唯一的运行态(runing)的那个进程,可以通过敲击“y”键关闭或打开运行态进程的加亮效果。
3.进程字段排序
默认进入top时,各进程是按照CPU的占用量来排序的,在下图中进程ID为28894的java进程排在第一(cpu占用142%),进程ID为574的java进程排在第二(cpu占用16%)。
敲击键盘“x”(打开/关闭排序列的加亮效果),top的视图变化如下:
可以看到,top默认的排序列是“%CPU”。
- 通过”shift + >”或”shift + <”可以向右或左改变排序列
下图是按一次”shift + >”的效果图,视图现在已经按照%MEM来排序。
实例2:显示 完整命令
命令:
top -c
输出:
说明:
实例3:以批处理模式显示程序信息
命令:
top -b
输出:
说明:
实例4:以累积模式显示程序信息
命令:
top -S
输出:
说明:
实例5:设置信息更新次数
命令:
top -n 2
输出:
说明:
表示更新两次后终止更新显示
实例6:设置信息更新时间
命令:
top -d 3
输出:
说明:
表示更新周期为3秒
实例7:显示指定的进程信息
命令:
top -p 574
输出:
说明:
5.top交互命令
在top 命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了s 选项, 其中一些命令可能会被屏蔽。
h 显示帮助画面,给出一些简短的命令总结说明
k 终止一个进程。
i 忽略闲置和僵死进程。这是一个开关式命令。
q 退出程序
r 重新安排一个进程的优先级别
S 切换到累计模式
s 改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s
f或者F 从当前显示中添加或者删除项目
o或者O 改变显示项目的顺序
l 切换显示平均负载和启动时间信息
m 切换显示内存信息
t 切换显示进程和CPU状态信息
c 切换显示命令名称和完整命令行
M 根据驻留内存大小进行排序
P 根据CPU使用百分比大小进行排序
T 根据时间/累计时间进行排序
W 将当前设置写入~/.toprc文件中