最佳答案

前段時間在開發一個使用SSD做快取的系統,在高速寫入資料時會出現大量的磁碟快取。太多的磁碟快取如果沒有及時的寫入磁碟中,在機器出現問題時是非常危險的,這樣會導致很多的資料丟失,但是如果實時的將資料刷入磁碟中,這樣寫入效率有太低了。為了弄明白linux系統的這種磁碟寫入特性,最近深入的學習了一下。 VFS(Virtual File System)的存在使得linux可以相容不同的檔案系統,例如ext3、ext4、xfs、ntfs等等,其不僅具有為所有的檔案系統實現一個通用的外介面的作用,還具有另一個與系統性能相關的重要作用——快取。VFS中引入了高速磁碟快取的機制,這屬於一種軟體機制,允許核心將原本存在磁碟上的某些資訊儲存在RAM中,以便對這些資料的進一步訪問能快速進行,而不必慢速訪問磁碟本身。高速磁碟快取可大致分為以下三種:

目錄項快取記憶體——主要存放的是描述檔案系統路徑名的目錄項物件

索引節點快取記憶體——主要存放的是描述磁碟索引節點的索引節點物件

頁快取記憶體——主要存放的是完整的資料頁物件,每個頁所包含的資料一定屬於某個檔案,同時,所有的檔案讀寫操作都依賴於頁快取記憶體。其是linux核心所使用的主要磁碟快取記憶體。 正是由於快取的引入,所以VFS檔案系統採用了檔案資料延遲寫的技術,因此,如果在呼叫系統介面寫入資料時沒有使用同步寫模式,那麼大多資料將會先儲存在快取中,待等到滿足某些條件時才將資料刷入磁盤裡。

核心是如何將資料刷入磁碟的呢?在看完以下兩點後就能得到答案。

1. 把髒頁寫入磁碟 正如我們所瞭解的,核心不斷用包含塊裝置資料的頁填充頁快取記憶體。只要程序修改了資料,相應的頁就被標記為髒頁,即把它的PG_dirty標誌位置。 Unix系統允許把髒緩衝區寫入塊裝置的操作延遲執行,因為這種策略可以顯著地提高系統的效能。對快取記憶體中的頁的幾次寫操作可能只需對相應的磁碟塊進行一次緩慢的物理更新就可以滿足。此外,寫操作沒有讀操作那麼緊迫,因為程序通常是不會因為延遲寫而掛起,而大部分情況都因為延遲讀而掛起。正是由於延遲寫,使得任一物理塊裝置平均為讀請求提供服務將多於寫請求。一個髒頁可能直到最後一刻(即直到系統關閉時)都一直逗留在主存中。然而,從延遲寫策略的侷限性來看,它有兩個主要的缺點: 一、如果發生了硬體錯誤或者電源掉電的情況,那麼就無法再獲得RAM的內容,因此,從系統啟動以來對檔案進行的很多修改就丟失了。 二、頁快取記憶體的大小(由此存放它所需的RAM的大小)就可要很大——至少要與所訪問塊裝置的大小不同。因此,在下列條件下把髒頁重新整理(寫入)到磁碟:

頁快取記憶體變得太滿,但還需要更多的頁,或者髒頁的數量已經太多。

自從頁變成髒頁以來已過去太長時間。

程序請求對塊裝置或者特定檔案任何待定的變化都進行重新整理。透過呼叫sync()、fsync()或者fdatasync()系統呼叫來實現。 緩衝區頁的引入是問題更加複雜。與每個緩衝區頁相關的緩衝區首部使核心能夠了解每個獨立塊緩衝區的狀態。如果至少有一個緩衝區首部的PG_Dirty標誌被置位,就應該設定相應緩衝區頁的PG_dirty標誌。當核心選擇要重新整理的緩衝區時,它掃描相應的緩衝區首部,並只把髒塊的內容有效的寫到磁碟。一旦核心把緩衝區的所有髒頁重新整理到磁碟,就把頁的PG_dirty標誌清0。

2. pdflush核心執行緒 早期版本的linux使用bdfllush核心執行緒系統地掃描頁快取記憶體以搜尋要重新整理的髒頁,並且使用另一個核心執行緒kupdate來保證所有的頁不會髒太長時間。linux 2.6用一組通用核心執行緒pdflush替代上述兩個執行緒。這些核心執行緒結構靈活,它們作用於兩個引數:一個指向執行緒要執行的函式的指標和一個函式要用的引數。系統中pdflush核心執行緒的數量是要動態調整的:pdflush執行緒太少時就建立,太多時就殺死。因為這些核心執行緒所執行的函式可以阻塞,所以建立多個而不是一個pdflush核心執行緒可以改善系統性能。根據下面的原則控制pdflush執行緒的產生和消亡:

必須有至少兩個,最多八個pdflush核心執行緒

如果最近一次pdflush變為空閒的時間超過了1s,就應該刪除一個pdflush執行緒 所有的pdflush核心執行緒都有pdflush_work描述符,其資料結構如下:

型別 欄位 說明 struct task_struct who 指向核心執行緒描述符的指標 void (*) (unsigned long) fn 核心執行緒所執行的回撥函式 unsigned long arg0 給回撥函式的引數 struct list head list pdflush_list連結串列的連結 unsigned long when_i_went_to_sleep 當核心執行緒可用時的時間(以jiffies表示)

當系統沒有要重新整理的髒頁時,pdflush執行緒會自動處於睡眠狀態,最後由pdflush_operation()函式來喚醒。那麼在這個過程中pdflush核心執行緒主要完成了哪些工作呢?其中一些工作與髒資料的重新整理有關。尤其是pdflush通常執行下面的回撥函式之一: 1. background_writeout(): 系統地掃描頁快取記憶體以搜尋要重新整理的髒頁。

為了得到需要重新整理的髒頁,就要徹底的搜尋與在磁碟上有映像的索引節點相應的所有address_space物件(是一棵搜尋樹)。由於頁快取記憶體可能有大量的頁,如果用一個單獨的執行流來掃描整個快取記憶體,會令CPU和磁碟長時間繁忙,因此,linux使用一種複雜的機制把對頁快取記憶體的掃描劃分為幾個執行流。當記憶體不足或者使用者顯式的(使用者態程序發出sync()系統呼叫等)呼叫請求重新整理操作時會執行wakeup_bdflush()函式。wakeup_bdflush()函式會呼叫pdflush_operation()喚醒pdflush核心執行緒,並委託它執行回撥函式background_writeout()。background_writeout()函式有效的從頁快取記憶體中獲得指定數量的髒頁,並把它寫回磁碟。此外,執行background_writeout()函式的pdflush核心執行緒只有在滿足以下兩個條件下才能被喚醒:一是對頁快取記憶體中的頁內容進行了修改,二是引起髒頁部分增加到超過某個髒背景閾值。背景閾值通常設定為系統中所有頁的10%,不過可以透過修改檔案/proc/sys/vm/dirty_background_ratio來調整該值。

繼續學習常見問答

50 你能舉例說明1萬有多大1億有多大嗎

就拿經常吃的大米舉個例子。普通北方大米600粒左右為五十克,一粒米就是十二分之一克。所以1萬粒大米有833克,成年人吃200g~300g米飯/每餐,一萬粒大米夠一個成年人吃一天。如果把這一萬粒大米數一遍,假設每秒數2粒(這個速度已經很快了)...


1億是多少個千萬

1.分析&根據題意,可以根據它們之間的進率去解答,10個千萬是1億,100個百萬是1億.解答即可.2.解答&解:一億裡面含有10個千萬;100個百萬;故答案為:10、100.3.點評&本題主要考查每相鄰的兩個計數單位之間的進率是10.1億就...


榮耀30長寬高多少

榮耀30的機身長度為16.03釐米,寬度為7.418釐米,底部厚度為0.81釐米,頂部厚度為0.847釐米,重約185克。榮耀30採用6.53英寸OLED,螢幕色彩1670萬色,DCI-P3廣色域解析度FHD+2400*1080。重新整理率...


沒有膝上型電腦開機密碼怎麼進去

1.隨身碟做個winpe,然後進去winpe清除密碼即可;2.買個ghost的裝機光碟,然後開機進入光碟winpe清除密碼即可;3.重灌系統也可以;4.如果是Android系統的平板電腦忘記鎖屏密碼解決方法:可以重新刷包或者wipedata...


qin7電腦密碼怎麼設定

您可以按照以下步驟設定QIN7電腦密碼:1.首先,您需要進入QIN7的主介面。在Windows系統中,您可以點選“開始”選單,然後搜尋“QIN7”,或者在瀏覽器中輸入“https://www.qin7.com/”。2.進入QIN7主介面後,...


聯想膝上型電腦如何解鎖開機密碼

聯想膝上型電腦解鎖開機密碼1、可以透過封裝系統盤PE中有清除開機密碼的選項解決。可以用隨身碟製作一個PE,然後從PE啟動進去裡面,有個清除開機密碼的選項,刪除或者修改開機登入密碼即可。此方法適合懂電腦技術的人。進u盤pe系統,桌面有清清除登...


華為資料恢復會覆蓋之前資料嗎

1.不會覆蓋之前的資料。2.因為華為資料恢復的過程是透過恢復軟體或專業服務進行的,這些方法不會對原有資料進行修改或覆蓋,而是透過讀取儲存裝置中的資料來進行恢復。3.華為資料恢復的目的是儘可能地恢復丟失或損壞的資料,而不是對現有資料進行修改或...


華為手機如何免root恢復檢視微信QQ聊天記錄

1、首先我們再電腦上面安裝一款恢復軟體,其實各大網站都有相關的軟體但是能不能使用我就不知道到了。各位最好使用本文中提到的相關軟體-強力安卓恢復精靈。2、接著開啟我們安裝好的強力安卓恢復精靈,可以看到軟體介面以及提示了我們的相關裝置資訊。3、...


銳龍r5 4500u和酷睿i5哪個好

銳龍r54500u和酷睿i5在效能上不相上下,但銳龍r54500u擁有更低的功耗和更強的續航能力。銳龍r54500u採用7nm工藝製造,擁有6個核心和6個執行緒,基本頻率2.3GHz,睿頻頻率4.0GHz,配備了8MB的二級快取和8MB的三...


r55500u處理器和i5哪個好

i5好。顯示卡效能差異和兩款處理器之間的效能差異。酷睿版不僅比銳龍版(僅有集顯)多配備了一塊MX450獨立顯示卡,處理器效能也較之對標r5有優勢。機器配套的銳龍r5-5500U的最高主頻為4GHz,而酷睿版裝載的i5-1135G7的最高主頻...