自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

當(dāng)CPU空閑時它都在做什么?

系統(tǒng) Linux
在 上篇文章中 我說了操作系統(tǒng)行為的基本原理是,在任何一個給定的時刻,在一個 CPU 上有且只有一個任務(wù)是活動的。但是,如果 CPU 無事可做的時候,又會是什么樣的呢?

 [[219194]]

上篇文章中 我說了操作系統(tǒng)行為的基本原理是,在任何一個給定的時刻,在一個 CPU 上有且只有一個任務(wù)是活動的。但是,如果 CPU 無事可做的時候,又會是什么樣的呢?

事實(shí)證明,這種情況是非常普遍的,對于絕大多數(shù)的個人電腦來說,這確實(shí)是一種常態(tài):大量的睡眠進(jìn)程,它們都在等待某種情況下被喚醒,差不多在 100% 的 CPU 時間中,都處于虛構(gòu)的“空閑任務(wù)”中。事實(shí)上,如果一個普通用戶的 CPU 處于持續(xù)的繁忙中,它可能意味著有一個錯誤、bug、或者運(yùn)行了惡意軟件。

因?yàn)槲覀儾荒苓`反我們的原理,一些任務(wù)需要在一個 CPU 上激活。首先是因?yàn)椋@是一個良好的設(shè)計:持續(xù)很長時間去遍歷內(nèi)核,檢查是否一個活動任務(wù),這種特殊情況是不明智的做法。最好的設(shè)計是沒有任何例外的情況。無論何時,你寫一個 if 語句,Nyan Cat 就會喵喵喵。其次,我們需要使用空閑的 CPU 去做一些事情,讓它們充滿活力,你懂得,就是創(chuàng)建天網(wǎng)計劃唄。

因此,保持這種設(shè)計的連續(xù)性,并領(lǐng)先于那些邪惡計劃一步,操作系統(tǒng)開發(fā)者創(chuàng)建了一個空閑任務(wù),當(dāng)沒有其它任務(wù)可做時就調(diào)度它去運(yùn)行。我們可以在 Linux 的 引導(dǎo)過程 中看到,這個空閑任務(wù)就是進(jìn)程 0,它是由計算機(jī)打開電源時運(yùn)行的第一個指令直接派生出來的。它在 rest_init 中初始化,在 initidlebootup_task 中初始化空閑調(diào)度類scheduling class。

簡而言之,Linux 支持像實(shí)時進(jìn)程、普通用戶進(jìn)程等等的不同調(diào)度類。當(dāng)選擇一個進(jìn)程變成活動任務(wù)時,這些類按優(yōu)先級進(jìn)行查詢。通過這種方式,核反應(yīng)堆的控制代碼總是優(yōu)先于 web 瀏覽器運(yùn)行。盡管在通常情況下,這些類返回 NULL,意味著它們沒有合適的任務(wù)需要去運(yùn)行 —— 它們總是處于睡眠狀態(tài)。但是空閑調(diào)度類,它是持續(xù)運(yùn)行的,從不會失?。核偸欠祷乜臻e任務(wù)。

好吧,我們來看一下這個空閑任務(wù)到底做了些什么。下面是 cpuidleloop,感謝開源能讓我們看到它的代碼:

  1. while (1) {
  2. while(!need_resched()) {
  3. cpuidle_idle_call();
  4. }
  5.  
  6. /*
  7. [Note: Switch to a different task. We will return to this loop when the idle task is again selected to run.]
  8. */
  9. schedule_preempt_disabled();
  10. }

cpuidleloop

我省略了很多的細(xì)節(jié),稍后我們將去了解任務(wù)切換,但是,如果你閱讀了這些源代碼,你就會找到它的要點(diǎn):由于這里不需要重新調(diào)度(即改變活動任務(wù)),它一直處于空閑狀態(tài)。以所經(jīng)歷的時間來計算,這個循環(huán)和其它操作系統(tǒng)中它的“堂兄弟們”相比,在計算的歷史上它是運(yùn)行的最多的代碼片段。對于 Intel 處理器來說,處于空閑狀態(tài)意味著運(yùn)行著一個 halt 指令:

  1. static inline void native_halt(void)
  2. {
  3. asm volatile("hlt": : :"memory");
  4. }

native_halt

hlt 指令停止處理器中的代碼執(zhí)行,并將它置于 halt 的狀態(tài)。奇怪的是,全世界各地數(shù)以百萬計的 Intel 類的 CPU 們花費(fèi)大量的時間讓它們處于 halt 的狀態(tài),甚至它們在通電的時候也是如此。這并不是高效、節(jié)能的做法,這促使芯片制造商們?nèi)ラ_發(fā)處理器的深度睡眠狀態(tài),以帶來著更少的功耗和更長休眠時間。內(nèi)核的 cpuidle 子系統(tǒng) 是這些節(jié)能模式能夠產(chǎn)生好處的原因。

現(xiàn)在,一旦我們告訴 CPU 去 halt(睡眠)之后,我們需要以某種方式讓它醒來。如果你讀過 上篇文章《你的操作系統(tǒng)什么時候運(yùn)行?》 ,你可能會猜到中斷會參與其中,而事實(shí)確實(shí)如此。中斷促使 CPU 離開 halt 狀態(tài)返回到激活狀態(tài)。因此,將這些拼到一起,下圖是當(dāng)你閱讀一個完全呈現(xiàn)的 web 網(wǎng)頁時,你的系統(tǒng)主要做的事情:

除定時器中斷外的其它中斷也會使處理器再次發(fā)生變化。如果你再次點(diǎn)擊一個 web 頁面就會產(chǎn)生這種變化,例如:你的鼠標(biāo)發(fā)出一個中斷,它的驅(qū)動會處理它,并且因?yàn)樗a(chǎn)生了一個新的輸入,突然進(jìn)程就可運(yùn)行了。在那個時刻, need_resched() 返回 true,然后空閑任務(wù)因你的瀏覽器而被踢出而終止運(yùn)行。

如果我們呆呆地看著這篇文章,而不做任何事情。那么隨著時間的推移,這個空閑循環(huán)就像下圖一樣:

在這個示例中,由內(nèi)核計劃的定時器中斷會每 4 毫秒發(fā)生一次。這就是滴答tick周期。也就是說每秒鐘將有 250 個滴答,因此,這個滴答速率(頻率)是 250 Hz。這是運(yùn)行在 Intel 處理器上的 Linux 的典型值,而其它操作系統(tǒng)喜歡使用 100 Hz。這是由你構(gòu)建內(nèi)核時在 CONFIG_HZ 選項(xiàng)中定義的。

對于一個空閑 CPU 來說,它看起來似乎是個無意義的工作。如果外部世界沒有新的輸入,在你的筆記本電腦的電池耗盡之前,CPU 將始終處于這種每秒鐘被喚醒 250 次的地獄般折磨的小憩中。如果它運(yùn)行在一個虛擬機(jī)中,那我們正在消耗著宿主機(jī) CPU 的性能和寶貴的時鐘周期。

在這里的解決方案是 動態(tài)滴答,當(dāng) CPU 處于空閑狀態(tài)時,定時器中斷被 暫停或重計劃,直到內(nèi)核知道將有事情要做時(例如,一個進(jìn)程的定時器可能要在 5 秒內(nèi)過期,因此,我們不能再繼續(xù)睡眠了),定時器中斷才會重新發(fā)出。這也被稱為無滴答模式。

最后,假設(shè)在一個系統(tǒng)中你有一個活動進(jìn)程,例如,一個長時間運(yùn)行的 CPU 密集型任務(wù)。那樣幾乎就和一個空閑系統(tǒng)是相同的:這些示意圖仍然是相同的,只是將空閑任務(wù)替換為這個進(jìn)程,并且相應(yīng)的描述也是準(zhǔn)確的。在那種情況下,每 4 毫秒去中斷一次任務(wù)仍然是無意義的:它只是操作系統(tǒng)的性能抖動,甚至?xí)鼓愕墓ぷ髯兊酶选inux 也可以在這種單一進(jìn)程的場景中停止這種固定速率的滴答,這被稱為 自適應(yīng)滴答 模式。最終,這種固定速率的滴答可能會 完全消失

對于閱讀一篇文章來說,CPU 基本是無事可做的。內(nèi)核的這種空閑行為是操作系統(tǒng)難題的一個重要部分,并且它與我們看到的其它情況非常相似,因此,這將幫助我們理解一個運(yùn)行中的內(nèi)核。

責(zé)任編輯:龐桂玉 來源: Linux中國
相關(guān)推薦

2019-09-15 19:11:14

CPU操作系統(tǒng)空閑

2015-11-03 15:22:31

CDO大數(shù)據(jù)首席數(shù)據(jù)官

2021-03-11 07:27:17

CPU空閑代碼

2013-02-22 09:59:22

移動醫(yī)療創(chuàng)業(yè)公司

2012-07-11 13:54:42

網(wǎng)頁重構(gòu)

2015-07-14 09:24:03

京東618MySQL

2015-05-13 11:20:02

DockerDocker實(shí)踐者PaaS

2023-09-12 16:36:39

操作系統(tǒng)CPU周期性

2009-03-12 11:08:00

技術(shù)顧問職場雜談

2013-11-22 09:43:11

王小川許朝軍搜狗

2022-07-06 15:07:47

React開發(fā)

2020-10-09 13:58:13

云服務(wù)商AWS谷歌

2021-08-26 11:09:51

systemdLinux

2023-12-18 16:02:04

OpenAI人工智能

2021-08-26 13:55:45

systemdLinux目標(biāo)

2024-04-16 10:09:42

2021-11-18 21:09:50

流批場景引擎

2012-11-27 10:17:04

2011-05-24 14:15:53

測試

2020-12-23 13:26:53

代碼麻省理工學(xué)院語言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號