Linux系統記憶體使用的體會及命令解釋(轉)
Linux系統記憶體使用的體會及命令解釋(轉)[@more@]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;
下面是對這些數值的解釋:
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的區別。
在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;
下面是對這些數值的解釋:
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-959684/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何檢視linux系統中空閒記憶體/實體記憶體使用/剩餘記憶體Linux記憶體
- Linux系統手動釋放記憶體快取Linux記憶體快取
- Linux記憶體子系統——Locking Pages(記憶體鎖定)Linux記憶體
- linux系統使用vmstat命令顯示虛擬記憶體狀態的方法教程Linux記憶體
- 虛擬記憶體系統——瞭解記憶體的工作原理記憶體
- 用以檢查Linux記憶體使用的5個命令Linux記憶體
- 使用 top 命令瞭解 Fedora 的記憶體使用情況記憶體
- Linux作業系統記憶體淺析Linux作業系統記憶體
- Rust記憶體安全解釋Rust記憶體
- Java記憶體模型,垃圾回收機制,常用記憶體命令及工具Java記憶體模型
- 32bit的linux系統記憶體分佈Linux記憶體
- 檢查 Linux 中記憶體使用情況的 8 條命令Linux記憶體
- Linux檢視伺服器記憶體使用情況的命令Linux伺服器記憶體
- Linux系統下分析記憶體使用情況的管理工具Linux記憶體
- linux記憶體管理(一)實體記憶體的組織和記憶體分配Linux記憶體
- (2)Linux效能調優之Linux記憶體體系Linux記憶體
- 檢視 Linux 系統中程序和使用者的記憶體使用情況Linux記憶體
- C/C++使用malloc為結構體陣列分配記憶體(及free釋放記憶體)的三種方法C++結構體陣列記憶體
- jvm記憶體設定及記憶體溢位、解決方案JVM記憶體溢位
- 在Linux中,如何檢查系統的CPU和記憶體使用情況?Linux記憶體
- 記憶體的分配與釋放,記憶體洩漏記憶體
- Linux系統程式設計—共享記憶體之mmapLinux程式設計記憶體
- 如何在 Linux 系統中判斷安裝、使用了多少記憶體Linux記憶體
- 利用 Shell 指令碼來監控 Linux 系統的記憶體指令碼Linux記憶體
- 查詢Linux系統記憶體總得不到想要的資訊?這有更好的命令Linux記憶體
- Linux記憶體不夠了?看看如何開啟虛擬記憶體增加記憶體使用量Linux記憶體
- Linux實體記憶體管理Linux記憶體
- vector 的記憶體釋放記憶體
- 使用 vmstat 命令確定記憶體使用情況記憶體
- [Linux]共享記憶體Linux記憶體
- [轉載] Java直接記憶體與堆記憶體Java記憶體
- 計算機作業系統——虛擬記憶體與實體記憶體計算機作業系統記憶體
- Linux共享記憶體的管理Linux記憶體
- windows10系統使用自帶記憶體檢測工具檢測記憶體好壞的方法Windows記憶體
- Sieve—Android 記憶體分析系統Android記憶體
- 作業系統-記憶體管理作業系統記憶體
- 作業系統——記憶體管理作業系統記憶體
- JAVA記憶體洩露的原因及解決Java記憶體洩露
- MySQL記憶體管理,記憶體分配器和作業系統MySql記憶體作業系統