使用uptime或者top命令,都可以看到一个负载的输出,形如load average: 0.00, 0.03, 0.00,这个负载到底是什么东西呢,man文档里只是一笔带过,没有具体的给出负载的定义。
负载的统计,必然是由内核完成的,因此在内核源码中找答案是再好不过的事情了,找来2.6.21的内核源码,开始探索。
节选部分源码:
|
//kernel/timer.c
|
load(t) = ( load(t-1)*exp(i) + n(t)*(2048-exp(i)) ) / 2048
load(t-1)为上次计算出的结果
n(t)为t时刻的活动进程数
计算方式是累加各个CPU的运行队列中running和uninterruptible的值 再乘以2048
计算方式如下:
|
|
exp(1) = 1884
exp(5) = 2014
exp(15) = 2037
exp(i) = 2048 * e^(-1/12/i)
从本质上看负载是完全由过去的一段时间里每个CPU上的活动进程数决定的,但并不是在数值上等同于每秒钟需要进行调度的进程数,具体的计算过程是个比较复杂的过程。
相关专题
- Windows操作系统安装 (15669篇文章)
- 系统优化大全 (18186篇文章)
- Linux频道 (8088篇文章)
- 系统管理 (2252篇文章)
- 系统安全设置 (23646篇文章)
- 操作系统常见故障解析 (4419篇文章)
- 配置安全的操作系统 (9880篇文章)
- 系统安装手册 (20918篇文章)
- 系统备份专题 (17615篇文章)
- Linux集群技术 (8416篇文章)
- 安装qmail全套功略 (18次浏览)
- TurboLinux 入门教程:第七课 TurboLinux简介 (18次浏览)
- Linux系统管理员秘技:用快捷命令一招制胜 (18次浏览)
- Linux系统命令分类详解 (1) (18次浏览)
- Linux下使用aMsn详解 (18次浏览)
- 你会在Linux下用POP3收Web电子邮箱吗? (18次浏览)
- 在Linux中用三款工具轻松制作网页 (18次浏览)
- Linux上的偷窺裝置 (1394的使用) (18次浏览)
- 深入浅出分析Linux内核漏洞的问题 (18次浏览)
- Linux内核调试工具:Kdb应用指南(4) (18次浏览)



