查看: 7434|回复: 0
打印 上一主题 下一主题

新手学堂 Linux操作系统中关于负载的定义

[复制链接]
跳转到指定楼层
1#
发表于 2007-9-9 15:31:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
台州网址导航
使用uptime或者top命令,都可以看到一个负载的输出,形如load average: 0.00, 0.03, 0.00,这个负载到底是什么东西呢,man文档里只是一笔带过,没有具体的给出负载的定义。

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

  节选部分源码:
  1. //kernel/timer.c


  2. 1254 active_tasks = count_active_tasks();

  3. 1256 CALC_LOAD(avenrun[0], EXP_1, active_tasks);
  4. 1257 CALC_LOAD(avenrun[1], EXP_5, active_tasks);
  5. 1258 CALC_LOAD(avenrun[2], EXP_15, active_tasks);




  6. //include/linux/sched.h

  7. 110 #define FSHIFT      11      /* nr of bits of precision */
  8. 111 #define FIXED_1     (1< 112 #define LOAD_FREQ   (5*HZ)      /* 5 sec intervals */
  9. 113 #define EXP_1       1884        /* 1/exp(5sec/1min) as fixed-point */
  10. 114 #define EXP_5       2014        /* 1/exp(5sec/5min) */
  11. 115 #define EXP_15      2037        /* 1/exp(5sec/15min) */

  12. 117 #define CALC_LOAD(load,exp,n) \
  13. 118     load *= exp; \
  14. 119     load += n*(FIXED_1-exp); \
  15. 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

  计算方式如下:
  1. 1946 unsigned long nr_active(void)
  2. 1947 {
  3. 1948 unsigned long i, running = 0, uninterruptible = 0;
  4. 1949
  5. 1950 for_each_online_cpu(i) {
  6. 1951 running += cpu_rq(i)->nr_running;
  7. 1952 uninterruptible += cpu_rq(i)->nr_uninterruptible;
  8. 1953 }
  9. 1954
  10. 1955 if (unlikely((long)uninterruptible < 0))
  11. 1956 uninterruptible = 0;
  12. 1957
  13. 1958 return running + uninterruptible;
  14. 1959 }


  15. 1226 static unsigned long count_active_tasks(void)
  16. 1227 {
  17. 1228 return nr_active() * FIXED_1;
  18. 1229 }
复制代码
exp(1) = 1884
  exp(5) = 2014
  exp(15) = 2037
  exp(i) = 2048 * e^(-1/12/i)

  从本质上看负载是完全由过去的一段时间里每个CPU上的活动进程数决定的,但并不是在数值上等同于每秒钟需要进行调度的进程数,具体的计算过程是个比较复杂的过程。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

网站推广
关于我们
  • 台州朗动科技(Tzweb.com)拥有多年开发网站平台系统门户手机客户端等业务的成功经验。主要从事:政企网站,系统平台,微信公众号,各类小程序,手机APP客户端,浙里办微应用,浙政钉微应用、主机域名、虚拟空间、后期维护等服务,满足不同企业公司的需求,是台州地区领先的网络技术服务商!

Hi,扫描关注我

Copyright © 2005-2026 站长论坛 All rights reserved

Powered by 站长论坛 with TZWEB Update Techonolgy Support

快速回复 返回顶部 返回列表