Linux 內(nèi)存管理機(jī)制簡(jiǎn)介
在Linux中經(jīng)常發(fā)現(xiàn)空閑內(nèi)存很少,似乎所有的內(nèi)存都被系統(tǒng)占用了,表面感覺(jué)是內(nèi)存不夠用了,其實(shí)不然。這是Linux內(nèi)存管理的一個(gè)優(yōu)秀特性,在這方面,區(qū)別于 Windows的內(nèi)存管理。主要特點(diǎn)是,無(wú)論物理內(nèi)存有多大,Linux 都將其充份利用,將一些程序調(diào)用過(guò)的硬盤數(shù)據(jù)讀入內(nèi)存,利用內(nèi)存讀寫的高速特性來(lái)提高Linux系統(tǒng)的數(shù)據(jù)訪問(wèn)性能。而Windows 是只在需要內(nèi)存時(shí),才為應(yīng)用程序分配內(nèi)存,并不能充分利用大容量的內(nèi)存空間。換句話說(shuō),每增加一些物理內(nèi)存,Linux 都將能充分利用起來(lái),發(fā)揮了硬件投資帶來(lái)的好處,而Windows只將其做為擺設(shè),即使增加8GB甚至更大。
本文引用地址:http://www.biyoush.com/article/148699.htmLinux 的這一特性,主要是利用空閑的物理內(nèi)存,劃分出一部份空間,做為 cache 和 buffers ,以此提高數(shù)據(jù)訪問(wèn)性能。
1、什么是 cache ?
頁(yè)高速緩存(cache)是 Linux內(nèi)核實(shí)現(xiàn)的一種主要磁盤緩存。它主要用來(lái)減少對(duì)磁盤的I/O操作。具體地講,是通過(guò)把磁盤中的數(shù)據(jù)緩存到物理內(nèi)存中,把對(duì)磁盤的訪問(wèn)變?yōu)閷?duì)物理內(nèi)存的訪問(wèn)。
磁盤高速緩存的價(jià)值在于兩個(gè)方面:第一,訪問(wèn)磁盤的速度要遠(yuǎn)遠(yuǎn)低于訪問(wèn)內(nèi)存的速度,因此,從內(nèi)存訪問(wèn)數(shù)據(jù)比從磁盤訪問(wèn)速度更快。第二,數(shù)據(jù)一旦被訪問(wèn),就很有可能在短期內(nèi)再次被訪問(wèn)到。
頁(yè)高速緩存是由內(nèi)存中的物理頁(yè)組成的,緩存中每一頁(yè)都對(duì)應(yīng)著磁盤中的多個(gè)塊。每當(dāng)內(nèi)核開(kāi)始執(zhí)行一個(gè)頁(yè)I/O操作時(shí)(通常是對(duì)普通文件中頁(yè)大小的塊進(jìn)行磁盤操作),首先會(huì)檢查需要的數(shù)據(jù)是否在高速緩存中,如果在,那么內(nèi)核就直接使用高速緩存中的數(shù)據(jù),從而避免訪問(wèn)磁盤。
舉個(gè)例子,當(dāng)使用文本編輯器打開(kāi)一個(gè)源程序文件時(shí),該文件的數(shù)據(jù)就被調(diào)入內(nèi)存。編輯該文件的過(guò)程中,越來(lái)越多的數(shù)據(jù)會(huì)相繼被調(diào)入內(nèi)存頁(yè)。最后,當(dāng)你編譯它的時(shí)候,內(nèi)核可以直接使用頁(yè)高速緩存中的頁(yè),而不需要重新從磁盤讀取該文件了。因?yàn)橛脩敉鶗?huì)反復(fù)讀取或操作同一個(gè)文件,所以頁(yè)高速緩存能減少大量的磁盤操作。
2、cache 如何更新?
由于頁(yè)高速緩存的緩存作用,寫操作實(shí)際上會(huì)被延遲。當(dāng)頁(yè)高速緩存中的數(shù)據(jù)比后臺(tái)存儲(chǔ)的數(shù)據(jù)更新時(shí),那么該數(shù)據(jù)就被稱做臟數(shù)據(jù)。在內(nèi)存中累積起來(lái)的臟頁(yè)最終必須被寫回磁盤。在以下兩種情況發(fā)生時(shí),臟頁(yè)被寫回磁盤:
◆當(dāng)空閑內(nèi)存低于一個(gè)特定的閾值時(shí),內(nèi)核必須將臟頁(yè)寫回磁盤,以便釋放內(nèi)存。
◆當(dāng)臟頁(yè)在內(nèi)存中駐留時(shí)間超過(guò)一個(gè)特定的閾值時(shí),內(nèi)核必須將超時(shí)的臟頁(yè)寫回磁盤,以確保臟頁(yè)不會(huì)無(wú)限期地駐留在內(nèi)存中。
在2.6內(nèi)核中,由一群內(nèi)核線程—pdflush后臺(tái)回寫例程統(tǒng)一執(zhí)行兩種工作。
首先,pdflush線程在系統(tǒng)中的空閑內(nèi)存低于一個(gè)特定的閾值時(shí),將臟頁(yè)刷新回磁盤。該后臺(tái)回寫例程的目的在于在可用物理內(nèi)存過(guò)低時(shí),釋放臟頁(yè)以重新獲得內(nèi)存。特定的內(nèi)存閾值可以通過(guò)dirty_background_ratio sysctl系統(tǒng)調(diào)用設(shè)置。當(dāng)空閑內(nèi)存比閾值:dirty_background_ratio還低時(shí),內(nèi)核便會(huì)調(diào)用函數(shù)wakeup_bdflush()喚醒一個(gè)pdflush線程,隨后pdflush線程進(jìn)一步調(diào)用函數(shù)background_writeout()開(kāi)始將臟頁(yè)寫回磁盤。函數(shù)background_ writeout()需要一個(gè)長(zhǎng)整型參數(shù),該參數(shù)指定試圖寫回的頁(yè)面數(shù)目。函數(shù)background_writeout()會(huì)連續(xù)地寫出數(shù)據(jù),直到滿足以下兩個(gè)條件:
◆已經(jīng)有指定的最小數(shù)目的頁(yè)被寫出到磁盤。
◆空閑內(nèi)存數(shù)已經(jīng)回升,超過(guò)了閾值dirty_background_ratio。
上述條件確保了pdflush操作可以減輕系統(tǒng)中內(nèi)存不足的壓力。回寫操作不會(huì)在達(dá)到這兩個(gè)條件前停止,除非pdflush寫回了所有的臟頁(yè),沒(méi)有剩下的臟頁(yè)可再被寫回了。
為了滿足第二個(gè)目標(biāo),pdflush后臺(tái)例程會(huì)被周期性喚醒(和空閑內(nèi)存是否過(guò)低無(wú)關(guān)),將那些在內(nèi)存中駐留時(shí)間過(guò)長(zhǎng)的臟頁(yè)寫出,確保內(nèi)存中不會(huì)有長(zhǎng)期存在的臟頁(yè)。如果系統(tǒng)發(fā)生崩潰,由于內(nèi)存處于混亂之中,所以那些在內(nèi)存中還沒(méi)來(lái)得及寫回磁盤的臟頁(yè)就會(huì)丟失,所以周期性同步頁(yè)高速緩存和磁盤非常重要。在系統(tǒng)啟動(dòng)時(shí),內(nèi)核初始化一個(gè)定時(shí)器,讓它周期地喚醒pdflush線程,隨后使其運(yùn)行函數(shù)wb_kupdate()。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評(píng)論