博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【性能测试】Linux系统监控-Top命令
阅读量:4100 次
发布时间:2019-05-25

本文共 1769 字,大约阅读时间需要 5 分钟。

前面转载的三篇文章主要介绍了性能测试的相关概念,其中有提到服务器,服务器的配置是性能测试中必须考虑的,而且性能测试中也必须监控服务器。

这篇文章主要介绍一下如何通过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相关信息。

你可能感兴趣的文章
前端设计之特效表单
查看>>
前端设计之CSS布局:上中下三栏自适应高度CSS布局
查看>>
Java的时间操作玩法实例若干
查看>>
JavaScript:时间日期格式验证大全
查看>>
责任链模式 Chain of Responsibility
查看>>
高并发与大数据解决方案概述
查看>>
解决SimpleDateFormat线程安全问题NumberFormatException: multiple points
查看>>
MySQL数据库存储引擎简介
查看>>
处理Maven本地仓库.lastUpdated文件
查看>>
CentOS7,玩转samba服务,基于身份验证的共享
查看>>
计算机网络-网络协议模型
查看>>
计算机网络-OSI各层概述
查看>>
Java--String/StringBuffer/StringBuilder区别
查看>>
分布式之redis复习精讲
查看>>
数据结构与算法7-栈
查看>>
Java并发编程 | 一不小心就死锁了,怎么办?
查看>>
(python版)《剑指Offer》JZ01:二维数组中的查找
查看>>
(python版)《剑指Offer》JZ06:旋转数组的最小数字
查看>>
(python版)《剑指Offer》JZ13:调整数组顺序使奇数位于偶数前面
查看>>
(python版)《剑指Offer》JZ28:数组中出现次数超过一半的数字
查看>>