首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux基础>基础入门>正文

Linux系统关于负载的定义

http://www.oklinux.cn  2008-05-12  赛迪网 korn  会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn

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


上一篇:修改Linux系统日期和时间   下一篇:Linux Shell下删除目录的命令

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·修改Linux系统日期和时间
·Linux Shell下删除目录的命令
·将Linux加入Windows域的方法
·学习园地:Linux下.bz2与.gz文件的区别
·菜鸟乐园:Linux系统Shell入门命令介绍
·Linux系统下激活网卡命令
·Linux系统下C语言编程 线程操作入门常识
·在Linux系统下建立Samba用户
·Linux系统下安装Weblogic小结
·在Linux终端中“\”和“--”所代表含义
·Linux系统网络安装总结
·Linux文本模式下上网简单命令
·学习园地:什么是Linux系统下的文件链接
·Linux系统配置VI或VIM的技巧
·Linux 2.6.12内核上加载一个简单的模块
·Linux下C语言编程的注意事项
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·企业为什么喜欢开源工作流软件(java)
·C++点滴:正确理解const相关的指针
·Linux文件系统现状
·新手进阶 对照DOS学Linux基本命令
·Ubuntu分区基础知识
·Ubuntu 8.10初次使用有感
·Ubuntu 8.10 ( Intrepid Ibex ) 软件源
·linux下的安装包介绍
·Windows系统用户转Linux新手常见问题整
·Linux系统下的多线程下载
·Linux系统的文件属性介绍
·关于Linux系统文件扩展名含义的介绍
  阅读排行
·Linux的GRUB引导程序配置方法大全
·从Grub命令行启动系统
·Linux 操作员基础教程
·iptable 基本配置方法
·firefox插件安装方法
·Linux通配符
·使用X-WIN32 EXCEED等软件显示远程LINU
·新手从零开始:Linux系统命令的使用
·Linux下tar bz gz等压缩包的压缩和解压
·Windows系统用户转Linux新手常见问题整
·新手进阶 对照DOS学Linux基本命令
·Linux简单加载新硬盘
·Unix Shell程序编写的方法详解
·『强烈推荐』Linux 下的大型/开源/网络
·Linux循序渐进:Vi的编辑操作及命令
网摘收藏: