在linux 在 CentOS 中我們可以通過top命令來查看cpu與記憶體佔用情況,下面我來分別舉例給各位朋友看看,有需要瞭解的朋友可進入參考。
(1)top使命
代碼如下 |
複製代碼 |
$ top -u oracle |
1、top命令
代碼如下 |
複製代碼 |
top -d 1 -p pid [,pid ...] //設定為delay 1s,預設是delay 3s
|
如果想根據記憶體使用量量進行排序,可以shift + m(Sort by memory usage)
(2)pmap
可以根據進程查看進程相關資訊佔用的記憶體情況,(進程號可以通過ps查看)如下所示:
代碼如下 |
複製代碼 |
$ pmap -d 14596 |
(3)ps
如下例所示:
代碼如下 |
複製代碼 |
$ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' 其中rsz是是實際記憶體 $ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' | grep oracle | sort -nrk5
|
其中rsz為實際記憶體,上例實現按記憶體排序,由大到小
靜態查看一個進程的記憶體使用量
1、pmap命令
2、ps命令
代碼如下 |
複製代碼 |
ps aux|grep process_name |
3、查看/proc/process_id/檔案夾下的status檔案
代碼如下 |
複製代碼 |
Name: php State: R (running) SleepAVG: 0% Tgid: 21574 Pid: 21574 PPid: 10005 TracerPid: 0 Uid: 1000 1000 1000 1000 Gid: 100 100 100 100 FDSize: 256 Groups: 16 100 VmPeak: 161740 kB VmSize: 161740 kB VmLck: 0 kB VmHWM: 107144 kB VmRSS: 107144 kB VmData: 106192 kB VmStk: 84 kB VmExe: 5588 kB VmLib: 7884 kB VmPTE: 268 kB Threads: 1 SigQ: 0/69632 SigPnd: 0000000000000000 ShdPnd: 0000000000000000 SigBlk: 0000000000000000 SigIgn: 0000000000001000 SigCgt: 00000001818040a7 CapInh: 0000000000000000 CapPrm: 0000000000000000 CapEff: 0000000000000000 Cpus_allowed: 00000000,00000000,00000000,0000000f Mems_allowed: 1 |
任務虛擬位址空間的大小 VmSize
應用程式正在使用的實體記憶體的大小 VmRSS
查看記憶體我們一般用free命令:
代碼如下 |
複製代碼 |
[root@scs-2 tmp]# free total used free shared buffers cached Mem: 3266180 3250004 16176 0 110652 2668236 -/+ buffers/cache: 471116 2795064 Swap: 2048276 80160 1968116
|
下面是對這些數值的解釋:
total:總計實體記憶體的大小。
used:已使用多大。
free:可用有多少。
Shared:多個進程共用的記憶體總額。
Buffers/cached:磁碟緩衝的大小。
第三行(-/+ buffers/cached):
used:已使用多大。
free:可用有多少。
第四行就不多解釋了。
區別:第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區別。 這兩個的區別在於使用的角度來看,第一行是從OS的角度來看,因為對於OS,buffers/cached 都是屬於被使用,所以他的可用記憶體是16176KB,已用記憶體是3250004KB,其中包括,核心(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.
第三行所指的是從應用程式角度來看,對於應用程式來說,buffers/cached 是等於可用的,因為buffer/cached是為了提高檔案讀取的效能,當應用程式需在用到記憶體的時候,buffer/cached會很快地被回收。
佔用記憶體的測量
測量一個進程佔用了多少記憶體,linux為我們提供了一個很方便的方法,/proc目錄為我們提供了所有的資訊,實際上top等工具也通過這裡來擷取相應的資訊。
代碼如下 |
複製代碼 |
/proc/meminfo 機器的記憶體使用量資訊 /proc/pid/maps pid為進程號,顯示當前進程所佔用的虛擬位址。 /proc/pid/statm 進程所佔用的記憶體 [root@localhost ~]# cat /proc/self/statm 654 57 44 0 0 334 0 |
輸出解釋
CPU 以及CPU0。。。的每行的每個參數意思(以第一行為例)為:
參數 解釋 /proc//status
代碼如下 |
複製代碼 |
Size (pages) 任務虛擬位址空間的大小 VmSize/4 Resident(pages) 應用程式正在使用的實體記憶體的大小 VmRSS/4 Shared(pages) 共用頁數 0 Trs(pages) 程式所擁有的可執行虛擬記憶體的大小 VmExe/4 Lrs(pages) 被映像到任務的虛擬記憶體空間的庫的大小 VmLib/4 Drs(pages) 程式資料區段和使用者態的棧的大小 (VmData+ VmStk )4 dt(pages) 04 |
查看機器可用記憶體
代碼如下 |
複製代碼 |
/proc/28248/>free total used free shared buffers cached Mem: 1023788 926400 97388 0 134668 503688 -/+ buffers/cache: 288044 735744 Swap: 1959920 89608 1870312 |
我們通過free命令查看機器空閑記憶體時,會發現free的值很小。這主要是因為,在linux中有這麼一種思想,記憶體不用白不用,因此它儘可能的cache和buffer一些資料,以方便下次使用。但實際上這些記憶體也是可以立刻拿來使用的。
所以 空閑記憶體=free+buffers+cached=total-used