CPU使用率和Load Average的关系

CPU使用率和Load Average的关系:

         拿去医院体检做一个例子:

         用户:待检查的同学

         CPU:检查的科室(B超、眼科。。。。)

1、  Load 高,CPU使用率低 :

眼科一共有3个医生,检查有次序,必须前一个医生检查结束了才能到下一个医生处理

由于第一个医生的检查耗时比较长,导致后面很多同学排队,但是接下去2个医生都处于空闲状态。

Load:等待的同学,由于等待的同学较多,所以Load的值较高

CPU使用率:只有一个医生处于工作状态,所以CPU的使用率为33.33%

2、  Load低,CPU使用率高:

假设B超科室有和眼科同样多的医生,但是每个医生之间的工作是独立的。

来一个新同学的时间,大约是检查完一个同学的时间。

Load:等待的同学,基本<=1

CPU使用率:每个医生都处于忙碌状态,CPU使用率接近100%

个人觉得这个例子举的比较好理解,CPU就像科室(含多个 医生),如果里面只有1个医生看病,另外2个闲着,CPU利用率是33.3%,然后外面很多排队等待使用CPU的人,这些就是排队的进程了,他们都是竞争 想要使用CPU,排队等待的人多,就是说明CPU的竞争比较激烈,就是系统平均负载Load Average。所以,cpu被占用了,利用率可能不高的,但是排队等待使用的进程很多,Load却高。所以,测试的时候,不能只看CPU利用率,也要看 系统平均负载Load Average。

关于系统平均负载Load Average 的计算,可以参考这篇文章 :http://blog.csdn.net/hello_yang213/article/details/7455480 

发布了259 篇原创文章 · 获赞 316 · 访问量 93万+

猜你喜欢

转载自blog.csdn.net/u014756827/article/details/103886344