zoukankan      html  css  js  c++  java
  • Linux的load average的含义

    Linux AS3.0 top命令的Load average 含义及性能参考基值 ?

    下面文章中的      “  数据是每隔5秒钟检查一次活跃的进程数,然后根据这个数值算出来的。如果这个数除以CPU的数目,结果高于5的时候就表明系统在超负荷运转了。”   

    具体是什么意思, 如果是cpu为8颗(双核,4核不知道如何算),目前load average 为: 20.22,20.03,18.99 应该不算超负荷运作了 ?
    ======================================================
    $ uptime
    11:12:26 up 3:44, 4 users, load average: 0.38, 0.31, 0.19
    上面的输出,load average后面分别是1分钟、5分钟、15分钟的负载情况。数据是每隔5秒钟检查一次活跃的进程数,然后根据这个数值算出来的。如果这个数除以CPU的数目,结果高于5的时候就表明系统在超负荷运转了。其算法(摘自Linux 2.4的内核代码)如下:

    文件: include/linux/sched.h:

    #define FSHIFT 11 /* nr of bits of precision */
    #define FIXED_1 (1<<FSHIFT) /* 1.0 as fixed-point */
    #define LOAD_FREQ (5*HZ) /* 5 sec intervals */
    #define EXP_1 1884 /* 1/exp(5sec/1min) as fixed-point, 2048/pow(exp(1), 5.0/60) */
    #define EXP_5 2014 /* 1/exp(5sec/5min), 2048/pow(exp(1), 5.0/300) */
    #define EXP_15 2037 /* 1/exp(5sec/15min), 2048/pow(exp(1), 5.0/900) */

    #define CALC_LOAD(load,exp,n) \
    load *= exp; \
    load += n*(FIXED_1-exp); \
    load >>= FSHIFT;

    /**********************************************************/

    文件: kernel/timer.c:
    unsigned long avenrun[3];

    static inline void calc_load(unsigned long ticks)
    {
    unsigned long active_tasks; /* fixed-point */
    static int count = LOAD_FREQ;

    count -= ticks;
    if (count < 0) {
    count += LOAD_FREQ;
    active_tasks = count_active_tasks();
    CALC_LOAD(avenrun[0], EXP_1, active_tasks);
    CALC_LOAD(avenrun[1], EXP_5, active_tasks);
    CALC_LOAD(avenrun[2], EXP_15, active_tasks);
    }
    }

    /**********************************************************/

    文件: fs/proc/proc_misc.c:

    #define LOAD_INT(x) ((x) >> FSHIFT)
    #define LOAD_FRAC(x) LOAD_INT(((x) & (FIXED_1-1)) * 100)

    static int loadavg_read_proc(char *page, char **start, off_t off,
    int count, int *eof, void *data)
    {
    int a, b, c;
    int len;

    a = avenrun[0] + (FIXED_1/200);
    b = avenrun[1] + (FIXED_1/200);
    c = avenrun[2] + (FIXED_1/200);
    len = sprintf(page,"%d.%02d %d.%02d %d.%02d %ld/%d %d\n",
    LOAD_INT(a), LOAD_FRAC(a),
    LOAD_INT(b), LOAD_FRAC(b),
    LOAD_INT(c), LOAD_FRAC(c),
    nr_running(), nr_threads, last_pid);
    return proc_calc_metrics(page, start, off, count, eof, len);
    }
     
    ======================================================
     
    系统平均负载被定义为在特定时间间隔内运行队列中的平均进程树。如果一个进程满足以下条件则其就会位于运行队列中:
    - 它没有在等待I/O操作的结果
    - 它没有主动进入等待状态(也就是没有调用'wait')
    - 没有被停止(例如:等待终止)

    下面这个是算法,数学不好,看的不太懂,资料上是这么说的\

    load average怎么计算?

       为 了使内核可以高效计算load average,采用了fixed-point arithmetic。fixed-point arithmetic是一种非常快速的模拟浮点运算的方法,特别是在没有FPU(float point unit)部件的处理器上,非常有用。

    计算公式:load(t) = load(t-1) e^(-5/60) + n (1 - e^(-5/60)),迭代计算,其中n为run-queue length。

    为什么采用这个计算公式呢?

    由Exponential Smoothing方程有,Y(t)= Y(t-1) + a*[X(t) - Y(t-1)],whereX(t) is the input raw data, Y(t - 1) is the value due to the previoussmoothing iteration and Y(t) is the new smoothed value.

    令a=1-b,b为e^(-5/60),就可以得到load average的计算公式

    采用此公式的好处:局部的load抖动不会对load average造成重大影响,使其平滑。
  • 相关阅读:
    如何将SLIC集成到ESXi中
    System Board Replacement Notice
    分发器上的会话代理进程控制脚本使用说明
    lib和dll的区别与使用
    vs2017自动生成的#include“stdafx.h”详解及解决方案
    禅定是否一定要打坐,为什么?
    PE文件解析 基础篇
    灵修书籍
    HDU 2546 饭卡(01背包裸题)
    codeforces 767A Snacktower(模拟)
  • 原文地址:https://www.cnblogs.com/aquester/p/9891978.html
Copyright © 2011-2022 走看看