Ubuntu 12.04では、いくつかのApache2プロセス(1130の親とそれが生成した子)が実行されており、ご覧のとおり、それらには約300〜400mbの仮想メモリと10mbの常駐メモリがあります。
$ ps aux | grep Apache2
root 1130 0.0 0.1 149080 10600 ? Ss Jul11 0:03 /usr/sbin/Apache2 -k start
www-data 23440 0.0 0.3 163660 24096 ? S 10:46 0:01 /usr/sbin/Apache2 -k start
www-data 27349 0.0 0.3 163380 23768 ? S 13:16 0:01 /usr/sbin/Apache2 -k start
www-data 27949 0.0 0.3 163912 24300 ? S 13:36 0:01 /usr/sbin/Apache2 -k start
www-data 28568 0.0 0.3 161496 22852 ? S 14:15 0:00 /usr/sbin/Apache2 -k start
www-data 28622 0.0 0.3 163656 23924 ? S 14:18 0:00 /usr/sbin/Apache2 -k start
www-data 28874 0.0 0.3 163600 23636 ? S 14:33 0:00 /usr/sbin/Apache2 -k start
www-data 28881 0.0 0.1 149368 7840 ? S 14:33 0:00 /usr/sbin/Apache2 -k start
www-data 28884 0.0 0.2 152856 12768 ? S 14:33 0:00 /usr/sbin/Apache2 -k start
www-data 29459 0.0 0.1 149368 7788 ? S 15:07 0:00 /usr/sbin/Apache2 -k start
www-data 29531 0.0 0.1 149184 7256 ? S 15:10 0:00 /usr/sbin/Apache2 -k start
1000 29543 0.0 0.0 8112 900 pts/0 S+ 15:11 0:00 grep Apache2
メモリ使用量の尺度として仮想メモリと常駐メモリを使用する場合の問題は、これらのプロセスの多くが共有ライブラリを使用している可能性があるため、これらのプロセスの個々のメモリ使用量が正確でない可能性があることです。そのため、代わりにpmapがよく使用されます。 pmapは、プロセスの「書き込み可能/プライベート」合計を示します。これは、共有ライブラリを除外して、このプロセスの増分コストと見なすことができます。
したがって、特定のプロセス、たとえば23440を使用して、そのメモリ使用量を調べます。
$ pmap -d 23440
23440: /usr/sbin/Apache2 -k start
Address Kbytes Mode Offset Device Mapping
mapped: 0K writeable/private: 0K shared: 0K
わかりました、それは私に何も教えてくれませんでした。何が起こっている?
そのコマンドを使用するには、rootまたはプロセスが所有されているユーザーである必要があります。代わりにこれを試してください:
$ Sudo pmap -d 23440
$ Sudo pmap -d 1457
1457: /usr/sbin/httpd
Address Kbytes Mode Offset Device Mapping
00007ff9f23bf000 76 r-x-- 0000000000000000 0fd:00000 Zip.so
00007ff9f23d2000 2044 ----- 0000000000013000 0fd:00000 Zip.so
00007ff9f25d1000 8 rw--- 0000000000012000 0fd:00000 Zip.so
00007ff9f25d3000 12 r-x-- 0000000000000000 0fd:00000 libgpg-error.so.0.5.0
00007ff9f25d6000 2044 ----- 0000000000003000 0fd:00000 libgpg-error.so.0.5.0
00007ff9f27d5000 4 rw--- 0000000000002000 0fd:00000 libgpg-error.so.0.5.0
...
...
00007fff70db1000 84 rw--- 0000000000000000 000:00000 [ stack ]
00007fff70dff000 4 r-x-- 0000000000000000 000:00000 [ anon ]
ffffffffff600000 4 r-x-- 0000000000000000 000:00000 [ anon ]
mapped: 290336K writeable/private: 6288K shared: 580K