最佳答案

前段時間在開發一個使用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來調整該值。

繼續學習常見問答

車險報價哪家便宜

1、太平洋車險的價效比很高,在車險價格優惠方面力度比較大,緊跟網際網路時代,尤其在網上優惠更大,私家車業險可多省15%,而且萬以下,資料齊全,可一天賠付。2、平安車險也是在網上直銷的,省去了中間商的差價。其中私家車商業保險最多也可省15%,...


2023醫保每月幾號返款

一般是月底打錢,具體幾號要以參保地當地實際法規為準。每個月的醫療保險費用通常都是月底劃扣的,因此相關的資金打入到個人賬戶一般是每個月二十號左右的時間。不同地區會有不同的標準,因此具體每月幾號打錢,要以參保地當地的實際情況為準。大家可以直接查...


rog筆記本設定cpu溫度和電壓

ROG筆記本可以透過ROGGamingCenter軟體進行CPU溫度和電壓的設定。具體的操作步驟如下:1.開啟ROGGamingCenter:在Windows作業系統中,可以透過桌面快捷方式、工作列圖示或開始選單中的ROGGamingCen...


imessage刪除後怎麼恢復

第一步:恢復不小心刪掉的iMessage資訊,把資料蛙蘋果恢復專家下載到電腦上,下載的同時將刪掉的iMessage的iPhone手機用資料線連線到電腦上,可以選擇原裝資料線進行操作,這樣可以保證資料傳輸的穩定。第二步:下載完成之後,執行資料...


奧迪s4與rs4有什麼區別

主要區別是:1.售價和定位都不一樣。S4的廠商指導價為46.88萬元,是一款效能型車型。RS4的廠商指導價為81.28萬元,屬於高效能車型。2.不同型號和尺寸S4是轎車,尺寸為4770*1847*1404MM,軸距2825MM,後備箱容積4...


怎麼測量鋰電池容量

鋰電池容量測試是以滿電電壓和設定的終止電壓為引數的,因為鋰電池的最低放電電壓是2.75V,所以,小於3V的電壓已經對鋰電池測試沒有意義;固定電流放電一般用多少C表示,鋰電池一般用0.5C放電進行測試。  1、把電池充滿電,單隻鋰電池充充滿電...


怎麼檢視12pro電池實際容量

可以透過以下步驟檢視iPhone12Pro電池的實際容量:1.開啟手機,前往“設定”-“電池與效能”,並點選“電量百分比”。2.在彈出的頁面中,觀察電池電量百分比及電池容量。需要注意的是,不同版本的iOS系統可能會有所不同,可能會對檢視結果...


1+9r如何查電池容量

要查詢1+9r手機的電池容量,您可以按照以下步驟進行操作:1.開啟手機設定:點選手機主螢幕上的“設定”圖示,通常是一個齒輪或者有一個齒輪圖案。2.進入電池設定:在設定選單中,找到與電池相關的選項。這通常被標記為“電池”、“電源”或者“電池和...


豪沃防凍液怎麼排氣

豪沃防凍液排氣步驟如下:1.確認發動機已經冷卻至室溫狀態,不能在加熱狀態下進行排氣。2.打開發動機艙蓋,找到散熱器上方的排氣閥。3.使用專用的排氣鉗或者扳手扳動排氣閥鬆開,閥門上會有一些空氣和防凍液排出來。4.等到冷卻水滴出並且不再有汽泡冒...


excel表格文字框如何在手機上修改

WPS手機版表格插入文字框:1、開啟WPS,開啟表格檔案,點選左上角的編輯,然後點選左下角的方框,找到插入,點選文字框就可以插入文字框了。如何修改文字框哪?1、在手機表格中,點左下角的按鈕,打開了表格的屬性面板後,再點選:插入。2、在插入展...