LINUX進程記憶體佔用查看命令

來源:互聯網
上載者:User

在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命令

 代碼如下 複製代碼
pmap pid

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.