我在 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 随处使用。回收内存需要花费精力,只要系统不需要,它就不会费心。