久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

Linux內(nèi)存管理機制的示例分析

184次閱讀
沒有評論

共計 3341 個字符,預計需要花費 9 分鐘才能閱讀完成。

自動寫代碼機器人,免費開通

這篇文章主要為大家展示了“Linux 內(nèi)存管理機制的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓丸趣 TV 小編帶領(lǐng)大家一起研究并學習一下“Linux 內(nèi)存管理機制的示例分析”這篇文章吧。

下面來了解下 Linux 內(nèi)存管理機制:

一、物理內(nèi)存和虛擬內(nèi)存

我們知道,直接從物理內(nèi)存讀寫數(shù)據(jù)要比從硬盤讀寫數(shù)據(jù)要快的多,因此,我們希望所有數(shù)據(jù)的讀取和寫入都在內(nèi)存完成,而內(nèi)存是有限的,這樣就引出了物理內(nèi)存與虛擬內(nèi)存的概念。

物理內(nèi)存就是系統(tǒng)硬件提供的內(nèi)存大小,是真正的內(nèi)存,相對于物理內(nèi)存,在 Linux 下還有一個虛擬內(nèi)存的概念,虛擬內(nèi)存就是為了滿足物理內(nèi)存的不足而提出的策略,它是利用磁盤空間虛擬出的一塊邏輯內(nèi)存,用作虛擬內(nèi)存的磁盤空間被稱為交換空間(Swap Space)。

作為物理內(nèi)存的擴展,Linux 會在物理內(nèi)存不足時,使用交換分區(qū)的虛擬內(nèi)存,更詳細的說,就是內(nèi)核會將暫時不用的內(nèi)存塊信息寫到交換空間,這樣以來,物理內(nèi)存得到了釋放,這塊內(nèi)存就可以用于其它目的,當需要用到原始的內(nèi)容時,這些信息會被重新從交換空間讀入物理內(nèi)存。

Linux 的內(nèi)存管理采取的是分頁存取機制,為了保證物理內(nèi)存能得到充分的利用,內(nèi)核會在適當?shù)臅r候?qū)⑽锢韮?nèi)存中不經(jīng)常使用的數(shù)據(jù)塊自動交換到虛擬內(nèi)存中,而將經(jīng)常使用的信息保留到物理內(nèi)存。

要深入了解 Linux 內(nèi)存運行機制,需要知道下面提到的幾個方面:

Linux 系統(tǒng)會不時的進行頁面交換操作,以保持盡可能多的空閑物理內(nèi)存,即使并沒有什么事情需要內(nèi)存,Linux 也會交換出暫時不用的內(nèi)存頁面。這可以避免等待交換所需的時間。

Linux 進行頁面交換是有條件的,不是所有頁面在不用時都交換到虛擬內(nèi)存,Linux 內(nèi)核根據(jù)”最近最經(jīng)常使用“算法,僅僅將一些不經(jīng)常使用的頁面文件交換到虛擬內(nèi)存,有時我們會看到這么一個現(xiàn)象:Linux 物理內(nèi)存還有很多,但是交換空間也使用了很多。其實,這并不奇怪,例如,一個占用很大內(nèi)存的進程運行時,需要耗費很多內(nèi)存資源,此時就會有一些不常用頁面文件被交換到虛擬內(nèi)存中,但后來這個占用很多內(nèi)存資源的進程結(jié)束并釋放了很多內(nèi)存時,剛才被交換出去的頁面文件并不會自動的交換進物理內(nèi)存,除非有這個必要,那么此刻系統(tǒng)物理內(nèi)存就會空閑很多,同時交換空間也在被使用,就出現(xiàn)了剛才所說的現(xiàn)象了。關(guān)于這點,不用擔心什么,只要知道是怎么一回事就可以了。

交換空間的頁面在使用時會首先被交換到物理內(nèi)存,如果此時沒有足夠的物理內(nèi)存來容納這些頁面,它們又會被馬上交換出去,如此以來,虛擬內(nèi)存中可能沒有足夠空間來存儲這些交換頁面,最終會導致 Linux 出現(xiàn)假死機、服務(wù)異常等問題,Linux 雖然可以在一段時間內(nèi)自行恢復,但是恢復后的系統(tǒng)已經(jīng)基本不可用了。

因此,合理規(guī)劃和設(shè)計 Linux 內(nèi)存的使用,是非常重要的.

二、內(nèi)存的監(jiān)控

作為一名 Linux 系統(tǒng)管理員,監(jiān)控內(nèi)存的使用狀態(tài)是非常重要的,通過監(jiān)控有助于了解內(nèi)存的使用狀態(tài),比如內(nèi)存占用是否正常,內(nèi)存是否緊缺等等,監(jiān)控內(nèi)存最常使用的命令有 free、top 等,下面是某個系統(tǒng) free 的輸出:

[root@linuxeye ~]# free total used free shared buffers cached Mem: 3894036 3473544 420492 0 72972 1332348 -/+ buffers/cache: 2068224 1825812 Swap: 4095992 906036 3189956

每個選項的含義:

第一行:

total:物理內(nèi)存的總大小

used:已經(jīng)使用的物理內(nèi)存大小

free:空閑的物理內(nèi)存大小

shared:多個進程共享的內(nèi)存大小

buffers/cached:磁盤緩存的大小

第二行 Mem:代表物理內(nèi)存使用情況

第三行 (-/+ buffers/cached):代表磁盤緩存使用狀態(tài)

第四行:Swap 表示交換空間內(nèi)存使用狀態(tài)

free 命令輸出的內(nèi)存狀態(tài),可以通過兩個角度來查看:一個是從內(nèi)核的角度來看,一個是從應(yīng)用層的角度來看的。

從內(nèi)核的角度來查看內(nèi)存的狀態(tài)

就是內(nèi)核目前可以直接分配到,不需要額外的操作,即為上面 free 命令輸出中第二行 Mem 項的值,可以看出,此系統(tǒng)物理內(nèi)存有 3894036K,空閑的內(nèi)存只有 420492K,也就是 40M 多一點,我們來做一個這樣的計算:

3894036 – 3473544 = 420492

其實就是總的物理內(nèi)存減去已經(jīng)使用的物理內(nèi)存得到的就是空閑的物理內(nèi)存大小,注意這里的可用內(nèi)存值 420492 并不包含處于 buffers 和 cached 狀態(tài)的內(nèi)存大小。

如果你認為這個系統(tǒng)空閑內(nèi)存太小,那你就錯了,實際上,內(nèi)核完全控制著內(nèi)存的使用情況,Linux 會在需要內(nèi)存的時候,或在系統(tǒng)運行逐步推進時,將 buffers 和 cached 狀態(tài)的內(nèi)存變?yōu)?free 狀態(tài)的內(nèi)存,以供系統(tǒng)使用。

從應(yīng)用層的角度來看系統(tǒng)內(nèi)存的使用狀態(tài)

也就是 Linux 上運行的應(yīng)用程序可以使用的內(nèi)存大小,即 free 命令第三行 -/+ buffers/cached 的輸出,可以看到,此系統(tǒng)已經(jīng)使用的內(nèi)存才 2068224K,而空閑的內(nèi)存達到 1825812K,繼續(xù)做這樣一個計算:

420492+(72972+1332348)=1825812

通過這個等式可知,應(yīng)用程序可用的物理內(nèi)存值是 Mem 項的 free 值加上 buffers 和 cached 值之和,也就是說,這個 free 值是包括 buffers 和 cached 項大小的,對于應(yīng)用程序來說,buffers/cached 占有的內(nèi)存是可用的,因為 buffers/cached 是為了提高文件讀取的性能,當應(yīng)用程序需要用到內(nèi)存的時候,buffers/cached 會很快地被回收,以供應(yīng)用程序使用。

buffers 與 cached 的異同

在 Linux 操作系統(tǒng)中,當應(yīng)用程序需要讀取文件中的數(shù)據(jù)時,操作系統(tǒng)先分配一些內(nèi)存,將數(shù)據(jù)從磁盤讀入到這些內(nèi)存中,然后再將數(shù)據(jù)分發(fā)給應(yīng)用程序;當需要往文件中寫數(shù)據(jù)時,操作系統(tǒng)先分配內(nèi)存接收用戶數(shù)據(jù),然后再將數(shù)據(jù)從內(nèi)存寫到磁盤上。然而,如果有大量數(shù)據(jù)需要從磁盤讀取到內(nèi)存或者由內(nèi)存寫入磁盤時,系統(tǒng)的讀寫性能就變得非常低下,因為無論是從磁盤讀數(shù)據(jù),還是寫數(shù)據(jù)到磁盤,都是一個很消耗時間和資源的過程,在這種情況下,Linux 引入了 buffers 和 cached 機制。

buffers 與 cached 都是內(nèi)存操作,用來保存系統(tǒng)曾經(jīng)打開過的文件以及文件屬性信息,這樣當操作系統(tǒng)需要讀取某些文件時,會首先在 buffers 與 cached 內(nèi)存區(qū)查找,如果找到,直接讀出傳送給應(yīng)用程序,如果沒有找到需要數(shù)據(jù),才從磁盤讀取,這就是操作系統(tǒng)的緩存機制,通過緩存,大大提高了操作系統(tǒng)的性能。但 buffers 與 cached 緩沖的內(nèi)容卻是不同的。

buffers 是用來緩沖塊設(shè)備做的,它只記錄文件系統(tǒng)的元數(shù)據(jù)(metadata)以及 tracking in-flight pages,而 cached 是用來給文件做緩沖。更通俗一點說:buffers 主要用來存放目錄里面有什么內(nèi)容,文件的屬性以及權(quán)限等等。而 cached 直接用來記憶我們打開過的文件和程序。

為了驗證我們的結(jié)論是否正確,可以通過 vi 打開一個非常大的文件,看看 cached 的變化,然后再次 vi 這個文件,感覺一下兩次打開的速度有何異同,是不是第二次打開的速度明顯快于第一次呢?

接著執(zhí)行下面的命令:

find /* -name *.conf

看看 buffers 的值是否變化,然后重復執(zhí)行 find 命令,看看兩次顯示速度有何不同。

Linux 操作系統(tǒng)的內(nèi)存運行原理,很大程度上是根據(jù)服務(wù)器的需求來設(shè)計的,例如系統(tǒng)的緩沖機制會把經(jīng)常使用到的文件和數(shù)據(jù)緩存在 cached 中,linux 總是在力求緩存更多的數(shù)據(jù)和信息,這樣再次需要這些數(shù)據(jù)時可以直接從內(nèi)存中取,而不需要有一個漫長的磁盤操作,這種設(shè)計思路提高了系統(tǒng)的整體性能。

以上是“Linux 內(nèi)存管理機制的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!

向 AI 問一下細節(jié)

丸趣 TV 網(wǎng) – 提供最優(yōu)質(zhì)的資源集合!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-12-07發(fā)表,共計3341字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 洪雅县| 申扎县| 平度市| 德江县| 河间市| 三穗县| 沧州市| 富裕县| 白沙| 历史| 永仁县| 德州市| 灌南县| 武宣县| 会东县| 鹤峰县| 北川| 封丘县| 罗甸县| 襄垣县| 阳东县| 阜康市| 杨浦区| 正安县| 武定县| 天祝| 石首市| 衡阳市| 九龙坡区| 海原县| 怀安县| 正定县| 镇赉县| 闵行区| 彰武县| 丽水市| 莆田市| 朔州市| 栾城县| 惠州市| 长乐市|