CentOS查询进程占用的内存

2017-04-18 08:47:03 1469

1. ps aux命令

USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND

lizhibin  32986  0.0 13.8 916276 534748 ?       Ssl  10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

lizhibin  32988  0.0 13.8 768812 534272 ?       S    10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

lizhibin  32993  0.0 13.8 764704 534752 ?       S    10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

lizhibin  32994  0.0 13.8 764704 534752 ?       S    10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

lizhibin  32995  0.0 13.8 764704 534752 ?       S    10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

lizhibin  32996  0.0 13.8 764704 534752 ?       S    10:12   0:00 /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

VSZ:表示进程占用多少虚拟内存(kb)

RSS:表示进程占用多少物理内存(kb)

我们来简化一下命令:

ps aux | grep swoole | grep -v grep | awk -F ' ' '{print $5,$6}'

916276 534748

768812 534272

764704 534752

764704 534752

764704 534752

764704 534752

可以看到每个swoole的进程占用了月500+MB的物理内存。

 

2.使用pmap命令

pmap -d 32988

32988:   /usr/local/php_5.4.45/bin/php -c /usr/local/php_5.4.45/etc/php-swoole.ini /www/service.gamechat.37.com/server.php

Address           Kbytes Mode  Offset           Device    Mapping

0000000000400000   10272 r-x-- 0000000000000000 0fd:00000 php

0000000001007000       4 r---- 0000000000a07000 0fd:00000 php

0000000001008000      60 rw--- 0000000000a08000 0fd:00000 php

0000000001017000     140 rw--- 0000000000000000 000:00000   [ anon ]

0000000002a69000  301936 rw--- 0000000000000000 000:00000   [ anon ]

00007fcec91e4000  224380 rw--- 0000000000000000 000:00000   [ anon ]

命令输出第一行:执行程序以及参数。

Address: 内存开始地址

Kbytes: 占用内存的字节数(KB)

RSS: 保留内存的字节数(KB)

Dirty: 脏页的字节数(包括共享和私有的)(KB)

Mode: 内存的权限:read、write、execute、shared、private (写时复制)

Mapping: 占用内存的文件、或[anon](分配的内存)、或[stack](堆栈)

Offset: 文件偏移

Device: 设备名 (major:minor)

 

我们使用awk命令,计算Kbytes列的和

pmap -dq 32988 | awk -F ' ' 'BEGIN{sum=0}{sum+=$2}END{print sum}'

结果输出:768812KB,这个结果是ps命令中的虚拟内存大小。接下来过滤掉so的共享内存。

pmap -dq 32988 | awk -F ' ' 'BEGIN{sum=0}{if($6!~/\.so/)sum+=$2}END{print sum}'

结果输出:672284KB,和ps命令得出的物理内存数据不同。对命令进行调整:

pmap -dq 32988 | awk -F ' ' 'BEGIN{sum=0}{if($6~/\[/)sum+=$2}END{print sum}'

结果输出:539684KB,和ps命令得出的物理内存已经比较接近了。上面的命令,主要统计出进程[ anon ]、[ stack ]所占用的内存(堆栈)


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: