EC2でUbuntuServer 12.04LTSを実行しています。私は、通常のinitのものとともに、upstartの下でサービスとして実行されているいくつかのnode.jsデーモンを持っています。すべてのnode.jsデーモンが再起動するすべてのデプロイ後、「init」プロセスは約0.5MB /分で増加し始めます。デーモンの特定の1つを再起動すると、initは<50MBに戻ります。
UpstartがRAMを消費する原因となるプロセスは何をしているのでしょうか?
上からの出力:
8月1日23:51UTC
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
17627 root 20 0 307m 90m 3444 S 0 5.3 146:18.06 chef-client
1 root 20 0 67680 44m 1140 S 1 2.6 59:11.04 init
17857 appserve 20 0 927m 30m 7024 S 4 1.8 2:01.79 node
17963 appserve 20 0 732m 26m 6504 S 2 1.6 0:36.03 node
18363 appserve 20 0 728m 21m 6316 S 0 1.3 0:00.71 node
14798 postgres 20 0 533m 20m 19m S 0 1.2 1:38.83 postgres
18091 appserve 20 0 726m 16m 6320 S 0 1.0 0:00.66 node
14801 postgres 20 0 533m 16m 15m S 0 1.0 4:07.21 postgres
17993 postgres 20 0 538m 16m 12m S 0 1.0 0:09.56 postgres
17865 postgres 20 0 537m 16m 12m S 0 0.9 0:15.00 postgres
8月2日01:32UTC
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 20 0 116m 94m 1140 S 0 5.6 59:51.25 init
17627 root 20 0 304m 87m 3444 S 0 5.2 147:04.41 chef-client
17963 appserve 20 0 737m 35m 7192 S 1 2.1 1:25.47 node
17857 appserve 20 0 926m 27m 7028 S 3 1.6 5:41.82 node
18363 appserve 20 0 728m 22m 6316 S 0 1.3 0:00.98 node
14798 postgres 20 0 533m 20m 19m S 0 1.2 1:39.29 postgres
18091 appserve 20 0 726m 16m 6320 S 0 1.0 0:00.66 node
14801 postgres 20 0 534m 16m 15m S 0 1.0 4:08.34 postgres
17993 postgres 20 0 538m 16m 12m S 0 1.0 0:23.08 postgres
17865 postgres 20 0 537m 16m 13m S 0 1.0 0:30.20 postgres
**更新:stdoutには吐き出しすぎたようです。あなたの助けをありがとう、みんな! ****
簡単に言うと、システムはRAMとは何の関係もないため、upstartはRAMをすべて使い果たしています。システムはメモリ不足にさらされていないため、ほとんど=のままです。 RAMどこでも使用できます。メモリを再利用するには手間がかかり、システムに必要がない限り、気にする必要はありません。