性能监控命令top详解杭州多测师杭州多测师_王sir
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了性能监控命令top详解杭州多测师杭州多测师_王sir相关的知识,希望对你有一定的参考价值。
一、top命令介绍
top命令是Linux系统中常用的性能分析工具,可以实时地查看系统的运行情况,比如内存、CPU、负载以及各个进程的资源占用情况
二、top命令详解
第一行:top - 14:39:05 up 36 days, 21:26, 3 users, load average: 56.31, 55.92, 56.03
top:名称
14:39:05:系统当前时间
up 36 days, 21:26:系统以及运行的时间,和uptime命令相等
3 users:当前有3个用户在线
load average: 56.31, 55.92, 56.03:系统一定时间内的平均负载,分别是1分钟、5分钟、15分钟。
主要关注load average这个值,所谓系统负载就是:在一段时间内,CPU正在处理以及等待CPU处理的进程数之和。系统在同一时间运行的进程数和系统CPU核数相关,一般来说Load Average的数值别超过这台机器的总核数,就没什么问题。
第二行:Tasks: 265 total, 2 running, 263 sleeping, 0 stopped, 0 zombie
Tasks:任务,也就是进程
265 total:当前总共有265个任务,也就是265个进程
2 running:2个进程正在运行
263 sleeping:263个进程正在休眠
0 stopped:0个停止的进程
0 zombie:1个僵尸进程
第三行:%Cpu(s): 88.9 us, 7.9 sy, 0.0 ni, 1.7 id, 0.0 wa, 1.4 hi, 0.0 si, 0.0 st
%Cpu(s):CPU使用率
88.9 us:用户空间占用CPU时间的百分比(大部分进程都运行在用户态,通常都是希望用户空间CPU越高越好)
7.9 sy:内核空间占用CPU时间的百分比(Linux内核态占用的CPU时间,系统 CPU占用越高,表明系统某部分存在瓶颈。通常这个值越低越好)
0.0 ni:占用CPU时间的百分比(ni是nice的缩写,进程用户态的优先级,如果调整过优先级,那么展示的就是调整过nice值的进程消耗掉的CPU时间,如果系统中没有进程被调整过nice值,那么ni就显示为0)
1.7 id:空闲CPU占用率,等待进程运行
0.0 wa:等待输入输出的CPU时间百分比(CPU的处理速度是很快的,磁盘IO操作是非常慢的。wa表示 CPU 在等待 IO 操作完成所花费的时间。系统不应该花费大量的时间来等待 IO 操作,否则就说明 IO 存在瓶颈)
1.4 hi:CPU硬中断时间百分比(硬中断是硬盘、网卡等硬件设备发送给CPU的中断消息 )
0.0 si:CPU软中断时间百分比(软中断是由程序发出的中断 )
0.0 st:被强制等待(involuntary wait)虚拟 CPU 的时间,此时 Hypervisor 在为另一个虚拟处理器服务。
第四行:MiB Mem : 15508.4 total, 3858.4 free, 3369.3 used, 828.07 buff/cache
MiB Mem:内存
15508.4 total:物理内存总量
3858.4 free:空闲内存量
3369.3 used:已使用的内存量
828.07 buff/cache:用作内核缓存的内存量
第五行:MiB Swap: 4096.0 total, 3855.1 free, 240.9 used. 10823.7 avail Mem
MiB Swap:交换空间(虚拟内存,当内存不足的时候,把一部分硬盘空间虚拟城内存使用)
4096.0 total:交换区总量
3855.1 free:空闲交换区总量
240.9 used:使用的交换区总量
10823.7 avail Mem:可用于启动一个新应用的内存(物理内存),和free不同,它计算的是可回收的page cache和memory slab
第四行和第五行输出信息,等同于使用free -m命令。
三、top命令进程信息详解
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
PID:进程id
USER:进程所有者
PR:进程的优先级,越小优先级越高
NI:nice值,负值表示高优先级,正值表示低优先级
VIRT:进程使用的虚拟内存,单位是kb
RES:进程使用的物理内存,单位kb
SHR:进程使用的共享内存,单位kb
S:进程状态(S表示休眠,R表示正在运行, Z表示僵死状态,N表示该进程优先值为负数,I表示空闲状态)
%CPU:进程占用的CPU使用率
%MEM:进程使用的物理内存和总内存的百分比
TIME+:进程使用的CPU时间总计,单位1/100秒
COMMAND:命令行
上述列是top命令的默认显示,还有一些参数可以使用top的交互命令选择显示,按f键,选择需要展示的部分。
四、top命令行选项
五、top交互命令
六、top命令中VIRT、RES、SHR含义
VIRT:
1、进程需要的虚拟内存大小,包括进程使用的库、代码、数据,以及malloc、new分配的堆空间和分配的栈空间等;
2、假如进程新申请10MB的内存,但实际只使用了1MB,那么它会增长10MB,而不是实际的1MB使用量。
RES:
1、进程当前使用的内存大小,包括使用中的malloc、new分配的堆空间和分配的栈空间,但不包括swap out量;
2、包含其他进程的共享;
3、如果申请10MB的内存,实际使用1MB,它只增长1MB;
SHR:
1、进程当前使用的内存大小,包括使用中的malloc、new分配的堆空间和分配的栈空间,但不包括swap out量;
2、包含其他进程的共享;
3、如果申请10MB的内存,实际使用1MB,它只增长1MB;
上述三个值是从/proc/pid/statm文件中格式化读出来的,前三个值分别是VIRT、RES、SHR,单位是页,常见的是4kb。
以上是关于性能监控命令top详解杭州多测师杭州多测师_王sir的主要内容,如果未能解决你的问题,请参考以下文章
Excel xlsx file not supported两种解决办法杭州多测师杭州多测师_王sir
Python笔试题:给定一个非负整数num,反复将各个位上的数字相加,直到结果为一位数杭州多测师杭州多测师_王sir
jmeter中通过PerfMon Metrics Collector插件监控CPU和内存等等显示ConnectException连接超时杭州多测师_王sir