Linux記憶體管理

2021-04-20 13:18:44 字數 2377 閱讀 5775

首先我要說,我這是轉貼,轉的cu論壇上

nonameboy

的帖子,你可以連線過去看看。

今天因為要解釋系統中可用記憶體的大小,用google看了半天,還有在cu上找了關天,竞然沒有發現有比較好的章,估計很多人都沒有注意到,懂了以後又沒有整理出來。

在cu上看了很多文章說什麼memory leak和linux記憶體管理不好,事實都是因為不懂linux的記憶體管理引起的誤會。

linux記憶體使用的體會(原創)

linux的記憶體管理,實際上跟windows的記憶體管理有很 相像的地方,都是用虛擬記憶體這個的概念,說到這裡不得不罵ms,為什麼在很多時候還有很大的物理記憶體的時候,卻還是用到了pagefile. 所以才經常要跟一幫人吵著說pagefile的大小,以及如何分配這個問題,在linux大家就不用再吵什麼swap大小的問題,我個人認為,swap設 個512m已經足夠了,如果你問說512m的swap不夠用怎麼辦?只能說大哥你還是加記憶體吧,要不就檢查你的應用,是不是真的出現了memory leak.

夜也深了,就不再說廢話了。

在linux下檢視記憶體我們一般用command free

[root@nonamelinux ~]# free

total       used       free     shared    buffers     cached

mem:    386024     377116    8908      0      21280     155468

-/+ buffers/cache:     200368    185656

swap:    393552        0      393552

下面是對這些數值的解釋:

第二行(mem):

total:總計物理記憶體的大小。

used:已使用多大。

free:可用有多少。

shared:多個程序共享的記憶體總額。

buffers/cached:磁碟快取的大小。

第三行(-/+ buffers/cached):

used:已使用多大。

free:可用有多少。

第四行就不多解釋了。

區別:第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區別。

第三行所指的是從應用程式角度來看,對於應用程式來說,buffers/cached 是等於可用的,因為buffer/cached是為了提高檔案讀取的效能,當應用程式需在用到記憶體的時候,buffer/cached會很快地被**。

所以從應用程式的角度來說,可用記憶體=系統free memory+buffers+cached.

如上例:

185656=8908+21280+155468

接下來解釋什麼時候記憶體會被交換,以及按什麼方交換。

當可用記憶體少於額定值的時候,就會開會進行交換.

如何看額定值(rhel4.0):

#cat /proc/meminfo

交換將通過三個途徑來減少系統中使用的物理頁面的個數: 

1.減少緩衝與頁面cache的大小,

2.將系統v型別的記憶體頁面交換出去, 

事實上,少量地使用swap是不是影響到系統效能的。

linux記憶體使用的體會(原創)

下面是buffers與cached的區別。

buffers是指用來給塊裝置做的緩衝大小,他只記錄檔案系統的metadata以及 tracking in-flight pages.

cached是用來給檔案做緩衝。

那就是說:buffers是用來儲存,目錄裡面有什麼內容,許可權等等。

而cached直接用來記憶我們開啟的檔案,如果你想知道他是不是真的生效,你可以試一下,先後執行兩次命令#man x ,你就可以明顯的感覺到第二次的開打的速度快很多。

實驗:在一台沒有什麼應用的機器上做會看得比較明顯。記得實驗只能做一次,如果想多做請換乙個檔名。

#free

#man x

#free

#man x

#free

你可以先後比較一下free後顯示buffers的大小。

另乙個實驗:

#free

#ls /dev

#free

你比較一下兩個的大小,當然這個buffers隨時都在增加,但你有ls過的話,增加的速度會變得快,這個就是buffers/chached的區別。

呵呵,gentoo 的 wiki啊

相關的gentoo論壇裡的帖子

Linux記憶體管理

本文首先介紹一下linux記憶體管理方式,著重說明一下使用者空間的記憶體管理,包括linux虛擬對映以及glibc中malloc的實現 然後簡要介紹單程序多執行緒的記憶體管理方式,主要涉及各執行緒堆疊空間的分配 linux 採用兩級保護機制,隔離核心空間和使用者程式空間,使使用者程式無法直接訪問核心...

Linux記憶體管理

本文首先介紹一下linux記憶體管理方式,著重說明一下使用者空間的記憶體管理,包括linux虛擬對映以及glibc中malloc的實現 然後簡要介紹單程序多執行緒的記憶體管理方式,主要涉及各執行緒堆疊空間的分配 linux採用兩級保護機制,隔離核心空間和使用者程式空間,使使用者程式無法直接訪問核心,...

linux記憶體管理

名詞解釋 2.頁描述符 描述每乙個頁框的狀態資訊,所有的頁描述符都是儲存在mem map陣列中,每個描述符32個位元組。3.節點 系統物理記憶體被劃分為多個節點,每個節點內cpu訪問頁面的時間是相同的,對應的資料結構 節點描述符。4.管理區 每個節點又分為多個管理區,對應的資料結構 管理區描述符 1...