亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

Linux操作系統關于負載的定義

添加時間:2010-11-21  添加: admin 
 使用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上的活動進程數決定的,但并不是在數值上等同于每秒鐘需要進行調度的進程數,具體的計算過程是個比較復雜的過程。

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站