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

2016-02-20 13:24 4 1 收藏

有了下面这个Linux操作系统中关于负载的定义教程,不懂Linux操作系统中关于负载的定义的也能装懂了,赶紧get起来装逼一下吧!

【 tulaoshi.com - Linux教程 】

使用uptime或者top命令,都可以看到一个负载的输出,形如load average: 0.00, 0.03, 0.00,这个负载到底是什么东西呢,man文档里只是一笔带过,没有具体的给出负载的定义。

  负载的统计,必然是由内核完成的,因此在内核源码中找答案是再好不过的事情了,找来2.6.21的内核源码,开始探索。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)

  节选部分源码:

//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 112 #define LOAD_FREQ   (5*HZ)      /* 5 sec intervals */
 113 #define EXP_1       1884        /* 1/exp(5sec/1min) as fixed-point */
 114 #define EXP_5       2014        /* 1/exp(5sec/5min) */
 115 #define EXP_15      2037        /* 1/exp(5sec/15min) */

 117 #define CALC_LOAD(load,exp,n)
 118     load *= exp;
 119     load += n*(FIXED_1-exp);
 120     load = FSHIFT;

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

  load(t-1)为上次计算出的结果

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)

  计算方式是累加各个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 0)) 1956 uninterruptible = 0; 1957 1958 return running + uninterruptible; 1959 }

  1226 static unsigned long count_active_tasks(void) 1227 { 1228 return nr_active() * FIXED_1; 1229 }

  exp(1) = 1884 exp(5) = 2014 exp(15) = 2037 exp(i) = 2048 * e^(-1/12/i)

  从本质上看负载是完全由过去的一段时间里每个CPU上的活动进程数决定的,但并不是在数值上等同于每秒钟需要进行调度的进程数,具体的计算过程是个比较复杂的过程。

来源:https://www.tulaoshi.com/n/20160220/1647767.html

延伸阅读
    内核简介 内核,是一个操作系统的核心。它负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。     Linux的一个重要的特点就是其源代码的公开性,所有的内核源程序都可以在/usr/src/linux下找到,大部分应用软件也都是遵循GPL而设计的,你都可以获取相应的源程...
作者: 阿瑟瑞德 一 Linux简介 1.1 Linux的缘起--UNIX&GNU 1969年诞生于AT&T贝尔实验室的UNIX,至今已派生了二十多个分支,成为世界上影响最大、应用最广泛的操作系统。早期UNIX系统是源代码公开,具有详细文档并被大多数学校广泛研究的。从版本7开始,AT&T将UNIX商业化,并更换了许可协议。 为...
标签: windows 操作系统
首先要搞清楚的是,这里所说的“重装”是什么意思?其实,所谓“重装”,是指重新安装操作系统,从目前的实际情况出发,估计普通用户中很少会有朋友去选择Linux、OS/2、Unix等另类操作系统,因此我们这里所指的是重新安装Windows操作系统。 一般安装操作系统时,经常会涉及到全新安装、升级安装、Windows下安装、DOS下安装等安装...
  Linux可以与MS-DOS、OS/2、Windows等其他操作系统共存于同一台机器上。它们均为操作系统,具有一些共性,但是互相之间各有特色,有所区别。  目前运行在PC机上的操作系统主要有Microsoft的MS-DOS、Windows、Windows NT、IBM的OS/2等。早期的PC机用户普遍使用MS-DOS,因为这种操作系统对机器的硬件配置要求不高,而随...
  这是关于如何用各种可以得到的接口为Linux开发网络程序的系列文章的第一篇。就像大多数Unix-based的操作系统一样,Linux支持将TCP/IP作为本地的网络传输协议。在这个系列中,我们假定你已经比较熟悉Linux上的C编程和Linux的一些系统知识诸如signals,forking等等。 这篇文章是关于如何用BSD套接口创建网络程序的基础介绍 。在...

经验教程

255

收藏

48
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部