为什么 upstart 占用了我所有的内存?

为什么 upstart 占用了我所有的内存?

我在 EC2 中运行 Ubuntu Server 12.04 LTS。我有几个 node.js 守护进程作为 upstart 下的服务运行,还有常见的 init 内容。每次部署后,所有 node.js 守护进程都会重新启动,“init”进程开始以大约 0.5MB/分钟的速度增长。如果我重新启动某个守护进程,init 会回到 <50MB。

我的进程可能在做什么导致 upstart 消耗我的 RAM?

从顶部输出:

8 月 1 日 23:51(UTC)

  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:32 UTC

  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          

**更新:看起来输出到标准输出的内容太多了。谢谢大家的帮助!**

答案1

简而言之,upstart 占用了你所有的 RAM,因为系统没有其他事情需要用到 RAM。你的系统没有任何内存压力,所以它基本上只是让 RAM 随处使用。回收内存需要花费精力,只要系统不需要,它就不会费心。

相关内容