Linux系統記憶體使用量經驗

來源:互聯網
上載者:User

今天因為要解釋系統中可用記憶體的大小,用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會很快地被回收。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.