Linux操作系统中关于负载的定义
来源:互联网 发布:python 加法重载 编辑:程序博客网 时间:2024/06/08 06:29
新手学堂 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上的活动进程数决定的,但并不是在数值上等同于每秒钟需要进行调度的进程数,具体的计算过程是个比较复杂的过程。
- Linux操作系统中关于负载的定义
- linux内核中关于MACH_TYPE_OMAP_4430SDP的定义
- 操作系统中关于信号量操作的代码示例(Linux + windows)
- 操作系统中关于信号量操作的代码示例(Linux + windows)
- 关于Linux操作系统中LUN的队列深度(queue_depth)
- 关于linux中带有位的整形的定义
- 关于linux操作系统的grub
- 关于linux中DBG宏定义的使用总结
- 关于linux中DBG宏定义的使用总结
- 关于UNIX/Linux操作系统的技术文章
- 关于Linux操作系统的开机过程详解
- 关于linux操作系统启动的过程
- 关于linux操作系统的环境变量(env)
- 关于linux操作系统的log日志
- 关于Linux操作系统下别名的设置
- 关于Linux操作系统的开机过程详解
- 关于Linux操作系统的开机过程详解
- 关于linux操作系统的环境变量(env)
- 如何掌握JDK1.5枚举类型
- 几个重要的RedHat Linux内核文件介绍
- MFC学习记录 2.CTreeCtrl与CImageList
- New For Me And/Or The World
- 正则表达式30分钟入门教程
- Linux操作系统中关于负载的定义
- Linux操作系统中内存buffer和cache的区别
- Linux操作系统下关于Top命令的参数详解
- 如何利用Java虚拟Unix/Linux的文件路径
- 正则表达式参考文档
- Linux操作系统下查找漏洞的几种必备兵器
- proc文件系统5大功能
- Java内存管理思想
- 感染linux脚本程序技术