前面转载的三篇文章主要介绍了性能测试的相关概念,其中有提到服务器,服务器的配置是性能测试中必须考虑的,而且性能测试中也必须监控服务器。
这篇文章主要介绍一下如何通过Linux服务器自带的top命令监控运行情况,以下是直接top命令得到的信息:
系统统计信息
第一行:需要关注的是load avg这行,通过这三个值,我们能看出系统负载的发展趋势。比如过去1分钟、5分钟、15分钟的平均负载的值分别是0.0、0.0、0.0。能说明什么问题呢?压测后,系统的负载越来越多。这个load值,除以逻辑CPU的数量(我的是8),大于5就表明系统在超负荷运转了。后续会有一篇文章专门介绍CPU相关信息和CPU和load average的关系。
第二行:任务运行情况,运行的越多,系统肯定越累。僵尸进程的概念大家搜索一下,一般情况下,不会有僵尸进程。
第三行:这一行是CPU的信息,比较重要,需要关注us、sy、wa这3个值占用是否高。多少算高?好问题,us一般超过75%就算高,sy一般超过30%就算高,wa超过5%就算高。
第四行:主要记录的是内存使用情况。内存是计算机中重要的部件之一,它是与CPU进行沟通的桥梁。计算机中所有程序的运行都是在内存中进行的,因此内存的性能对计算机的影响非常大。
现代的操作系统为了最大利用内存,在内存中存放了缓存,因此内存利用率100%并不代表内存有瓶颈,衡量系统内有有瓶颈主要靠SWAP(与虚拟内存交换)交换空间利用率,一般情况下,SWAP交换空间利用率要低于70%,太多的交换将会引起系统性能低下。
第五行:上面说了,第4行,不能反应内存是否够用,最主要还是要看这一行。我上面图片中交换空间利用率0%,很明显内存足够。
进程信息
- PID:进程id
- USER:进程所有者用户名;
- PR:优先级。数值越大优先级越高;
- NI:nice值,负值表示高优先级,正值表示低优先级
- VIRT:进程使用的虚拟内存总量,单位KB。VIRT=SWAP+RES SWAP:进程使用的虚拟内存中被换出的大小,单位KB
- RES:进程使用的、未被换出的物理内存大小,单位KB,RES=CODE+DATA SHR:共享内存大小,单位KB
- SHR:共享内存大小,单位KB
- S:进程状态。D表示不可中断的睡眠状态;R表示运行;S表示睡眠;T表示跟踪/停止;Z表示僵尸进程。
- %CPU:上次更新到现在的CPU占用百分比 ;
- %MEM:进程使用的物理内存百分比 ;
- TIME+:进程使用的CPU时间总计,单位1/100秒;
- COMMAND:命令名/命令行
TOP常用交互命令
通过 top 的内部命令对进程的显示方式进行控制,交互命令使用方法:先top命令得到信息,再输入交互命令
s – 改变画面更新频率
l – 关闭或开启第一部分第一行 top 信息的表示
t – 关闭或开启第一部分第二行 Tasks 和第三行 Cpus 信息的表示
m – 关闭或开启第一部分第四行 Mem 和 第五行 Swap 信息的表示
N – 以 PID 的大小的顺序排列表示进程列表
P – 以 CPU 占用率大小的顺序排列进程列表
M – 以内存占用率大小的顺序排列进程列表
h – 显示帮助
n – 设置在进程列表所显示进程的数量
q – 退出 top
在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况
TOP常用组合命令
使用格式:
top [-] [b] [d] [p] [q] [c] [C] [S] [s] [n]
参数说明:
b: 以批处理模式操作
d:指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
p: 通过指定监控进程ID来仅仅监控某个进程的状态。
q: 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
S:指定累计模式。
s:使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
i:使top不显示任何闲置或者僵死进程。
c: 显示整个命令行而不只是显示命令名。
组合命令:top -b -d 1 > /data/文件名.txt (将top的信息按每1秒重定向到服务器目录某个文件)
下篇文章主要介绍Linux服务器CPU相关信息。