Linux記憶體使用的體會(轉)
Linux記憶體使用的體會(轉)[@more@]Linux記憶體使用的體會
今天因為要解釋系統中可用記憶體的大小,用google看了半天,還有在CU上找了關天,競然沒有發現有比較好的章,估計很多人都沒有注意到,懂了以後又沒有整理出來。
在CU上看了很多文章說什麼memory leak和linux記憶體管理不好,事實都是因為不懂linux的記憶體管理引起的誤會。
晚上我把這幾天看到,跟自已的一些想法,實驗總結出來,供大家參考,如果有什麼錯誤的時候請直接指出來,同時感謝wiki論壇不知名的作者以及他寫的FAQ Linux Memory Management。
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的區別。
這兩個的區別在於使用的角度來看,第一行是從OS的角度來看,因為對於OS,buffers/cached 都是屬於被使用,所以他的可用記憶體是8908KB,已用記憶體是377116KB,其中包括,核心(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.
第三行所指的是從應用程式角度來看,對於應用程式來說,buffers/cached 是等於可用的,因為buffer/cached是為了提高檔案讀取的效能,當應用程式需在用到記憶體的時候,buffer/cached會很快地被回收。
所以從應用程式的角度來說,可用記憶體=系統free memory+buffers+cached.
如上例:
185656=8908+21280+155468
接下來解釋什麼時候記憶體會被交換,以及按什麼方交換。
當可用記憶體少於額定值的時候,就會開會進行交換.
如何看額定值(RHEL4.0):
#cat /proc/meminfo
交換將透過三個途徑來減少系統中使用的物理頁面的個數:
1.減少緩衝與頁面cache的大小,
2.將系統V型別的記憶體頁面交換出去,
3.換出或者丟棄頁面。(Application 佔用的記憶體頁,也就是實體記憶體不足)。
事實上,少量地使用swap是不是影響到系統效能的。
下面是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的區別。
今天因為要解釋系統中可用記憶體的大小,用google看了半天,還有在CU上找了關天,競然沒有發現有比較好的章,估計很多人都沒有注意到,懂了以後又沒有整理出來。
在CU上看了很多文章說什麼memory leak和linux記憶體管理不好,事實都是因為不懂linux的記憶體管理引起的誤會。
晚上我把這幾天看到,跟自已的一些想法,實驗總結出來,供大家參考,如果有什麼錯誤的時候請直接指出來,同時感謝wiki論壇不知名的作者以及他寫的FAQ Linux Memory Management。
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的區別。
這兩個的區別在於使用的角度來看,第一行是從OS的角度來看,因為對於OS,buffers/cached 都是屬於被使用,所以他的可用記憶體是8908KB,已用記憶體是377116KB,其中包括,核心(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.
第三行所指的是從應用程式角度來看,對於應用程式來說,buffers/cached 是等於可用的,因為buffer/cached是為了提高檔案讀取的效能,當應用程式需在用到記憶體的時候,buffer/cached會很快地被回收。
所以從應用程式的角度來說,可用記憶體=系統free memory+buffers+cached.
如上例:
185656=8908+21280+155468
接下來解釋什麼時候記憶體會被交換,以及按什麼方交換。
當可用記憶體少於額定值的時候,就會開會進行交換.
如何看額定值(RHEL4.0):
#cat /proc/meminfo
交換將透過三個途徑來減少系統中使用的物理頁面的個數:
1.減少緩衝與頁面cache的大小,
2.將系統V型別的記憶體頁面交換出去,
3.換出或者丟棄頁面。(Application 佔用的記憶體頁,也就是實體記憶體不足)。
事實上,少量地使用swap是不是影響到系統效能的。
下面是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的區別。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617542/viewspace-960765/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux系統記憶體使用的體會及命令解釋(轉)Linux記憶體
- Linux 使用記憶體分析Linux記憶體
- 如何檢視linux系統中空閒記憶體/實體記憶體使用/剩餘記憶體Linux記憶體
- 轉 linux 記憶體釋放Linux記憶體
- 解析Linux中的記憶體使用Linux記憶體
- linux記憶體管理(一)實體記憶體的組織和記憶體分配Linux記憶體
- Linux記憶體使用詳解Linux記憶體
- Linux 記憶體管理:記憶體對映Linux記憶體
- Linux記憶體點滴:使用者程式記憶體空間Linux記憶體
- 在linux檢視記憶體的大小(轉)Linux記憶體
- Linux記憶體不夠了?看看如何開啟虛擬記憶體增加記憶體使用量Linux記憶體
- 記憶體上的linux記憶體Linux
- linux的記憶體管理Linux記憶體
- [轉載] Java直接記憶體與堆記憶體Java記憶體
- aix的記憶體使用AI記憶體
- 獲取linux可用記憶體 剩餘記憶體Linux記憶體
- 轉摘_如何使linux擴充套件使用 大記憶體Linux套件記憶體
- 【轉】java中的記憶體溢位和記憶體洩漏Java記憶體溢位
- 檢視主機的記憶體使用情 (轉)記憶體
- 堆記憶體和棧記憶體詳解(轉載)記憶體
- 清理linux記憶體Linux記憶體
- linux記憶體管理Linux記憶體
- LINUX 記憶體管理Linux記憶體
- linux共享記憶體Linux記憶體
- MySQL記憶體使用MySql記憶體
- Linux AS 使用記憶體檔案系統Linux記憶體
- Linux讀寫實體記憶體Linux記憶體
- Linux共享記憶體的管理Linux記憶體
- Linux中的記憶體管理Linux記憶體
- C++學習體會:記憶體管理C++記憶體
- 記憶體管理篇——實體記憶體的管理記憶體
- 如何檢視Linux的記憶體使用狀況Linux記憶體
- JavaScript對記憶體的使用JavaScript記憶體
- RMAN 對記憶體的使用記憶體
- JAVA記憶體管理 [轉]Java記憶體
- 轉:Oracle 記憶體分析Oracle記憶體
- Java的記憶體 -JVM 記憶體管理Java記憶體JVM
- 【Linux】Linux 的快取記憶體Linux快取記憶體