在Linux系统中,uptime、w、top等命令都会有系统平均负载load average的输出,那么什么是系统平均负载呢?
系统平均负载被定义为在特定时间间隔内运行队列中的平均进程树。如果一个进程满足以下条件则其就会位于运行队列中:
- 它没有在等待I/O操作的结果
- 它没有主动进入等待状态(也就是没有调用’wait’)
- 没有被停止(例如:等待终止)
例如:
[root@www2 init.d]# top
7:21pm up 3 days, 3:32, 3 users, load average: 8.38, 5.31, 4.19
上面的输出,load average后面分别是1分钟、5分钟、15分钟内运行队列中的平均进程数量。数据是每隔5秒钟检查一次活跃的进程数,然后根据这个数值算出来的。
load average也可以理解为每秒钟CPU等待运行的进程个数。只要每个CPU的当前活动进程数不大于3那么系统的性能就是良好的,如果每个CPU的任务数大于5,那么就表示这台机器的性能有严重问题。
对于上面的例子来说,假设系统有两个CPU,那么其每个CPU的当前任务数为:8.38/2=4.19。这表示该系统的性能是可以接受的。
阅读(1455) | 评论(0) | 转发(0) |