使用top工具檢視到suse linux的記憶體佔用率很大,可能97%以上,我知道這是linux的記憶體使用機制,先將記憶體整個管理起來,需要的時候在分配給單個程序。但是如果我需要檢視系統真實的記憶體佔用率應該怎麼做
如下顯示free是顯示的當前記憶體的使用,-m的意思是m位元組來顯示內容.我們來一起看看.
$ free -m
total used free shared buffers cached
mem: 1002 769 232 0 62 421
-/+ buffers/cache: 286 715
swap: 1153 0 1153
真實記憶體占用 = used-buffers-cached = 286
第一部分mem行:
total 記憶體總數: 1002m
used 已經使用的記憶體數: 769m
free 空閒的記憶體數: 232m
shared 當前已經廢棄不用,總是0
buffers buffer 快取記憶體數: 62m
cached page 快取記憶體數:421m
關係:total(1002m) = used(769m) + free(232m)
第二部分(-/+ buffers/cache):
(-buffers/cache) used記憶體數:286m (指的第一部分mem行中的used - buffers - cached)
(+buffers/cache) free記憶體數: 715m (指的第一部分mem行中的free + buffers + cached)
可見-buffers/cache反映的是被程式實實在在吃掉的記憶體,而+buffers/cache反映的是可以挪用的記憶體總數。
第三部分是指交換分割槽, 我想不講大家都明白.
我想大家看了上面,還是很暈.第一部分(mem)與第二部分(-/+ buffers/cache)的結果中有關used和free為什麼這麼奇怪.
其實我們可以從二個方面來解釋.
對作業系統來講是mem的引數.buffers/cached 都是屬於被使用,所以它認為free只有232.
對應用程式來講是(-/+ buffers/cach).buffers/cached 是等同可用的,因為buffer/cached是為了提高程式執行的效能,當程式使用記憶體時,buffer/cached會很快地被使用。
所以,以應用來看看,以(-/+ buffers/cache)的free和used為主.所以我們看這個就好了.另外告訴大家一些常識.linux為了提高磁碟和記憶體訪問效率, linux做了很多精心的設計, 除了對dentry進行快取(用於vfs,加速檔案路 徑名到inode的轉換), 還採取了兩種主要cache方式:buffer cache和page cache。前者針對磁碟塊的讀寫,後者針對檔案inode的讀寫。這些cache能有效縮短了 i/o系統呼叫(比如read,write,getdents)的時間。
記住記憶體是拿來用的,不是拿來看的.不象windows, 無論你的真實物理記憶體有多少,他都要拿硬碟交換檔案來讀.這也就是windows為什麼常常提示虛擬空間不足的原因.你們想想,多無聊,在記憶體還有大部分的時候,拿出一部分硬碟空間來充當記憶體.硬碟怎麼會快過記憶體.所以我們看linux,只要不用swap的交換空間,就不用擔心自己的記憶體太少.如果常常 swap用很多,可能你就要考慮加物理記憶體了.這也是linux看記憶體是否夠用的標準哦.
記憶體利用率
記憶體利用率 有多個命令提供有關系統記憶體利用率的相關資訊。最流行的是free 和pmap。free命令 free 命令顯示可用的物理記憶體量,其中包括總物理記憶體量 已用物理記憶體量 可用物理記憶體量。它也為交換空間顯示同樣的統計資訊,還顯示核心使用的記憶體快取大小和緩衝區的大小。圖7 5 顯示了...
HashMap的記憶體利用率
有規律的整數 字串 test public void testhashsize 這個時候往往不會構建鍊錶和紅黑色。而是底層真的是陣列。無規律的key test public void testhashsize 記憶體中陣列長度,元素個數。使用下面的 看看talbe中有多少不為空 int a 0 fo...
cpu利用率 CPU利用率錯誤
cpu利用率 cpu利用率是每個人用來衡量處理器效能的指標。netflix的高階效能架構師布倫丹 格雷格 brendan gregg 在第16屆年度南加州linux expo scale 上稱其為 五分鐘公共服務公告 但 cpu卻是一種誤導性的衡量指標,說明處理器的實際繁忙程度。布倫丹在他的閃電演講...