web-dev-qa-db-ja.com

なぜupstartがRAMをすべて使い果たしているのですか?

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には吐き出しすぎたようです。あなたの助けをありがとう、みんな! ****

4
wolak

簡単に言うと、システムはRAMとは何の関係もないため、upstartはRAMをすべて使い果たしています。システムはメモリ不足にさらされていないため、ほとんど=のままです。 RAMどこでも使用できます。メモリを再利用するには手間がかかり、システムに必要がない限り、気にする必要はありません。

1
David Schwartz