友善交流技术...

uptime load average 真实含义

上一篇 / 下一篇  2011-12-09 10:35:14 / 个人分类:性能测试专题

系统平均负载被定义为在特定时间间隔内运行队列中的平均进程树。如果一个进程满 足以下条件则其就会位于运行队列中:  

- 它没有在等待I/O操作的结果  

- 它没有主动进入等待状态(也就是没有调用'wait')   

- 没有被停止(例如:等待终止)  

 例如: root@CMS3:~# uptime
 10:38:20 up 115 days, 17:16,  4 users,  load average: 17.03, 17.04, 17.00

命令输出的最后内容表示在过去的1、5、15分钟内运行队列中的平均进程数量。  

一般来说只要每个CPU的当前活动进程数不大于1那么系统的性能就是良好的,如 果每个CPU的任务数大于1,那么就表示这台机器的性能有严重问题。

对 于上面的例子 来说,假设系统有4个CPU,那么其每个CPU的当前任务数为:17/4=4.25。这表示该系统的性能已经出现了问题的,通过查看cpu使用情况发现,


PID USER PR NI VIRT RES SHR S %CPU %MEM COMMAND                                    
4970 root  20  0 1498m 739m 9420 S  401 18.3  /usr/bin/java -Djava.util.logging.config.file=/usr/lo

java 进程使用CPU的比例在 401%这说明了4个CPU全部让这个服务给占用了。

这种情况下,说明了系统已经出现了瓶颈点,这个点是什么?至少说CPU已经承受不了,具体的原因,可能是在代码上面或是压力过大造成的,要分析了。至少通过监控,发出了CPU,已经是本次测试的瓶颈点。 

 

再看一个没有压力情况下的系统的负载情况

 

 root@CMS1:~# uptime
 10:59:23 up 36 days, 17:57,  9 users,  load average: 0.09, 0.11, 0.09

大家看一下这个没有压力情况下, load average: 0.09, 0.11, 0.09  也是四个CPU的系统,负载情况

 

Linux系统中,uptime、w、top等命令都会有系统平均负载load average的输出


TAG:

 

评分:0

我来说两句

Open Toolbar