霜天部落 | 关注LAMP高性能、高并发架构的设计与研究

Linux Load Average的含义

linux top命令中其他数据都比较清楚,只有load average不清楚到底是什么意思。今天特意Google了一下,原来load average显示的是最近1分钟、5分钟和15分钟的系统平均负载。load average就是一定时间内的load数量。在Linux系统中,uptime、w、top等命令都会有系统平均负载load average的输出。

load average

系统平均负载被定义为在特定时间间隔内运行队列中(在CPU上运行或者等待运行多少进程)的平均进程树。

如果一个进程满足以下条件则其就会位于运行队列中:

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

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

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

进程可运行状态时,它处在一个运行队列run queue中,与其他可运行进程争夺CPU时间。 系统的load是指正在运行running one和准备好运行runnable one的进程的总数。比如现在系统有2个正在运行的进程,3个可运行进程,那么系统的load就是5。

一般来说只要每个CPU的当前活动进程数不大于3那么系统的性能就是良好的,但实际情况是否如此,如何区分它们目前的状况是 “好”还是“糟糕”呢?需要继续研究。

关于进程的状态:在Linux中,进程分为三种状态,一种是阻塞的进程blocked process,一种是可运行的进程runnable process,另外就是正在运行的进程running process。当进程阻塞时,进程会等待I/O设备的数据或者系统调用。