快捷搜索:

Linux操作系统中关于负载的定义

应用uptime或者top敕令,都可以看到一个负载的输出,形如load average: 0.00, 0.03, 0.00,这个负载到底是什么器械呢,man文档里只是一笔带过,没有详细的给出负载的定义。

负载的统计,一定是由内核完成的,是以在内核源码中找谜底是再好不过的工作了,找来2.6.21的内核源码,开始探索。

节选部分源码:

//kernel/timer.c

1254 active_tasks = count_active_tasks();

1256 CALC_LOAD(avenrun[0], EXP_1, active_tasks);

1257 CALC_LOAD(avenrun[1], EXP_5, active_tasks);

1258 CALC_LOAD(avenrun[2], EXP_15, active_tasks);

//include/linux/sched.h

110 #define FSHIFT   11   /* nr of bits of precision */

111 #define FIXED_1   (1>= FSHIFT;

load(t) = ( load(t-1)*exp(i) + n(t)*(2048-exp(i)) ) / 2048

load(t-1)为上次谋略出的结果

n(t)为t时候的活动进程数

谋略要领是累加各个CPU的运行行列步队中running和uninterruptible的值 再乘以2048

谋略要领如下:

1946 unsigned long nr_active(void)

1947 {

1948 unsigned long i, running = 0, uninterruptible = 0;

1949

1950 for_each_online_cpu(i) {

1951 running += cpu_rq(i)->nr_running;

1952 uninterruptible += cpu_rq(i)->nr_uninterruptible;

1953 }

1954

1955 if (unlikely((long)uninterruptible

exp(1) = 1884

exp(5) = 2014

exp(15) = 2037

exp(i) = 2048 * e^(-1/12/i)

从本色上看负载是完全由以前的一段光阴里每个CPU上的活动进程数抉择的,但并不是在数值上等同于每秒钟必要进行调整的进程数,详细的谋略历程是个对照繁杂的历程。

您可能还会对下面的文章感兴趣: