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

转载 2007年09月28日 01:26:00
原贴:http://blog.chinaunix.net/u/17030/showart_342669.html

新手学堂 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<


  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 < 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上的活动进程数决定的,但并不是在数值上等同于每秒钟需要进行调度的进程数,具体的计算过程是个比较复杂的过程。

 

相关文章推荐

PXE+kickstart安装Linux操作系统

PXE+kickstart安装操作系统介绍 在服务器比较多的时候,利用PXE安装操作系统是比较简便的方法。下面开始。。。。 环境描述: server:redhat 6.4 ①安装DHCP服务。DHCP...

linux操作系统下部署Javaweb项目教程

操作系统: CentOS 6.9 64位工具:Xshell,Xftp,MySQL5.7,jdk1.8,tomcat8.0一,Xshell基本概念:Xshell可以在Windows界面下用来访问远端不同...

linux操作系统下c语言编程入门

linux操作系统下c语言编程入门  整理编写:007xiong  原文:Hoyt等  (一)目录介绍  1)Linux程序设计入门--基础知识  2)Linux程序设计入门--进程...

java开发第一个JNI示例程序(基于linux操作系统)--java调用native方法

大家都知道,通过jni可以实现java和c以及c++的交互,但是这对于新手来说,想实现自己的本地调用还是有一定困难,万事开头难,这里我将用一个最简单的程序向大家展示jni的真面目。项目的基本流程: ...

在Linux操作系统下安装JAVA8

原文地址:http://happyshome.cn/blog/deploy/java.html 本篇文章会介绍如何在Linux操作系统上安装和更新JAVA8。 ...

Linux操作系统下的时间设置方法介绍

Linux时钟分为系统时钟(System Clock)和硬件(Real Time Clock,简称RTC)时钟。系统时钟是指当前Linux Kernel中的时钟,而硬件时钟则是主板上由电池供电的时钟,...

15分钟搭建Linux操作系统+Oracle数据库的环境

一直想学习下Linux下Oracle数据库方面的运维,但从头安装Linux操作系统,再装Oracle数据库的过程确实非常繁琐,涉及到了很多的操作系统和数据库的配置,门槛高。最近才发现Oracle已经为...
  • pan_tian
  • pan_tian
  • 2014年09月24日 15:26
  • 12661

【Linux操作系统分析】进程——进程切换,进程的创建和撤销

1 进程 进程是程序执行时的一个实例,可以把它看作充分描述程序已经执行到何种程度的数据结构的汇集。 从内核的观点看,进程的目的是担当分配系统资源(CPU时间,内存等)的实体。 (早期的系统中)当...

imx6q处理器,linux操作系统平台搭建 从SD卡启动系统

本文是参考http://blog.csdn.net/girlkoo/article/details/44536447这篇文章,然后把移植过程和学习笔记再次留下. uboot的下载地址,在百度上搜索gi...
  • srf1986
  • srf1986
  • 2016年01月25日 21:32
  • 2044

安装linux操作系统--浪潮服务器

关于在浪潮服务器上安装RHEL操作系统。
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Linux操作系统中关于负载的定义
举报原因:
原因补充:

(最多只允许输入30个字)