亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
12下一頁(yè)
最近訪問(wèn)板塊 發(fā)新帖
查看: 4434 | 回復(fù): 13
打印 上一主題 下一主題

[進(jìn)程管理] 如何修改CFS算法為優(yōu)待IO進(jìn)程 [復(fù)制鏈接]

論壇徽章:
1
雙子座
日期:2014-01-24 10:23:13
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2014-11-17 16:08 |只看該作者 |倒序?yàn)g覽
10可用積分
我的想法是故意地減少I(mǎi)O進(jìn)程的運(yùn)行時(shí)間:修改代碼如下
static inline void
__update_curr(struct cfs_rq *cfs_rq, struct sched_entity *curr,
              unsigned long delta_exec)
{
        unsigned long delta_exec_weighted;
        struct task_struct *my_p;

+       my_p = task_of(curr);

        schedstat_set(curr->exec_max, max((u64)delta_exec, curr->exec_max));
//判斷當(dāng)前進(jìn)程是不是IO進(jìn)程
+       if(my_p->ioac.write_bytes > 0){
//是IO進(jìn)程則減慢vruntime的增長(zhǎng)
+              if(count_io > 1){
+                       curr->sum_exec_runtime += delta_exec;
+                      schedstat_add(cfs_rq, exec_clock, delta_exec);
+                       delta_exec_weighted = calc_delta_fair(delta_exec, curr);
+                       curr->vruntime += delta_exec_weighted;
+                       count_io --;
+                      if (entity_is_task(curr)) {  //組調(diào)度策略由update_curr函數(shù)移到這里做一個(gè)控制
+                               struct task_struct *curtask = task_of(curr);

+                               cpuacct_charge(curtask, delta_exec);
+                              account_group_exec_runtime(curtask, delta_exec);
+                       }
+               }else{//運(yùn)行IO進(jìn)程后不作記賬
+                       schedstat_add(cfs_rq, exec_clock, delta_exec);
+                       count_io++;
+               }
+       }else{//不是IO進(jìn)程則正常運(yùn)行
+               curr->sum_exec_runtime += delta_exec;
+               schedstat_add(cfs_rq, exec_clock, delta_exec);
+               delta_exec_weighted = calc_delta_fair(delta_exec, curr);
+               curr->vruntime += delta_exec_weighted;
+               if (entity_is_task(curr)) {
+                        struct task_struct *curtask = task_of(curr);

+                       cpuacct_charge(curtask, delta_exec);
+                       account_group_exec_runtime(curtask, delta_exec);
+               }
+       }
        update_min_vruntime(cfs_rq);
}

static void update_curr(struct cfs_rq *cfs_rq)
{
        struct sched_entity *curr = cfs_rq->curr;
        u64 now = rq_of(cfs_rq)->clock;
        unsigned long delta_exec;

        if (unlikely(!curr))
                return;
        /*
         * Get the amount of time the current task was running
         * since the last time we changed load (this cannot
         * overflow on 32 bits):
         */
        delta_exec = (unsigned long)(now - curr->exec_start);

        __update_curr(cfs_rq, curr, delta_exec);
        curr->exec_start = now;
-           if (entity_is_task(curr)) {//移到__update_curr函數(shù)中控制運(yùn)行
-                       struct task_struct *curtask = task_of(curr);

-                        cpuacct_charge(curtask, delta_exec);
-                       account_group_exec_runtime(curtask, delta_exec);
-               }
}


修改后性能并沒(méi)有提升,請(qǐng)各位大神給點(diǎn)自己的意見(jiàn),謝謝

最佳答案

查看完整內(nèi)容

此類問(wèn)題建議從業(yè)務(wù)模型方面優(yōu)化,效果可能更明顯,比如綁核,專核用于IO。。

論壇徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辭舊歲徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亞洲杯之卡塔爾
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08處女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技術(shù)圖書(shū)徽章
日期:2014-03-25 09:00:29
2 [報(bào)告]
發(fā)表于 2014-11-17 16:08 |只看該作者
盡量不帥氣 發(fā)表于 2014-11-18 16:17
首先謝謝你的回答,但瓶頸確實(shí)是在調(diào)度上邊,磁盤(pán)只用到了57%左右,就是上次我和你說(shuō)的那個(gè)raw設(shè)備寫(xiě)的問(wèn)題 ...

此類問(wèn)題建議從業(yè)務(wù)模型方面優(yōu)化,效果可能更明顯,比如綁核,專核用于IO。。

論壇徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辭舊歲徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亞洲杯之卡塔爾
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08處女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技術(shù)圖書(shū)徽章
日期:2014-03-25 09:00:29
3 [報(bào)告]
發(fā)表于 2014-11-18 08:47 |只看該作者
關(guān)鍵還要看你的測(cè)試環(huán)境中,CPU是否存在瓶頸。如果瓶頸不在CPU,那優(yōu)化調(diào)度是沒(méi)意義的。
通常IO的瓶頸都在磁盤(pán)上~~

論壇徽章:
16
2015亞冠之吉達(dá)阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉雞
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52雙魚(yú)座
日期:2014-02-22 13:07:56午馬
日期:2014-02-14 11:08:18雙魚(yú)座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
4 [報(bào)告]
發(fā)表于 2014-11-18 14:17 |只看該作者
CFS對(duì)io bound的進(jìn)程已經(jīng)有compensation的。仔細(xì)讀代碼。只是不像O(1)那樣搞個(gè)dynamic prio那么明顯。

論壇徽章:
1
雙子座
日期:2014-01-24 10:23:13
5 [報(bào)告]
發(fā)表于 2014-11-18 16:17 |只看該作者
首先謝謝你的回答,但瓶頸確實(shí)是在調(diào)度上邊,磁盤(pán)只用到了57%左右,就是上次我和你說(shuō)的那個(gè)raw設(shè)備寫(xiě)的問(wèn)題和2.6.18差遠(yuǎn)了,后來(lái)定位發(fā)現(xiàn)是調(diào)度器出了問(wèn)題。回復(fù) 2# humjb_1983


   

論壇徽章:
1
雙子座
日期:2014-01-24 10:23:13
6 [報(bào)告]
發(fā)表于 2014-11-18 16:22 |只看該作者
謝謝,我也是剛定位到raw設(shè)備IO性能在2.6.28內(nèi)核中是調(diào)度器的問(wèn)題的,目前剛接觸不久;
請(qǐng)問(wèn)那段代碼的實(shí)現(xiàn)具體在哪里呢?
還有既然做了優(yōu)化,為什么調(diào)度間隔還有2500us之多,而2.6.18內(nèi)核中只有1700us左右?上面的數(shù)據(jù)是我定位IO性能的結(jié)果,所用環(huán)境都是一樣的。回復(fù) 3# embeddedlwp


   

論壇徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辭舊歲徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亞洲杯之卡塔爾
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08處女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技術(shù)圖書(shū)徽章
日期:2014-03-25 09:00:29
7 [報(bào)告]
發(fā)表于 2014-11-18 16:33 |只看該作者
盡量不帥氣 發(fā)表于 2014-11-18 16:17
首先謝謝你的回答,但瓶頸確實(shí)是在調(diào)度上邊,磁盤(pán)只用到了57%左右,就是上次我和你說(shuō)的那個(gè)raw設(shè)備寫(xiě)的問(wèn)題 ...

此類問(wèn)題建議從業(yè)務(wù)模型方面優(yōu)化,效果可能更明顯,比如綁核,專核用于IO。。

論壇徽章:
16
2015亞冠之吉達(dá)阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉雞
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52雙魚(yú)座
日期:2014-02-22 13:07:56午馬
日期:2014-02-14 11:08:18雙魚(yú)座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
8 [報(bào)告]
發(fā)表于 2014-11-18 16:41 |只看該作者
回復(fù) 5# 盡量不帥氣


IO bound的進(jìn)程一般sleep比較多的。wakeup的時(shí)候,vruntime = min_vruntime - sysctl_sched_latency/2  (我看的upstream kernel)


   

論壇徽章:
1
雙子座
日期:2014-01-24 10:23:13
9 [報(bào)告]
發(fā)表于 2014-11-18 17:13 |只看該作者
對(duì),是有這個(gè)東西,但是它取的是max(se->vruntime,cfs_rq->min_vruntime-sysctl_sched_latency);
這樣的話補(bǔ)償效果并不明顯。
回復(fù) 8# embeddedlwp


   

論壇徽章:
1
雙子座
日期:2014-01-24 10:23:13
10 [報(bào)告]
發(fā)表于 2014-11-18 17:17 |只看該作者
這樣的話,是不是對(duì)機(jī)器的要求較高,要是在其他機(jī)器上CPU不夠用,會(huì)不會(huì)出問(wèn)題?回復(fù) 7# humjb_1983


   
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過(guò)ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP