产生node.js子进程导致云代工厂的僵尸进程

时间:2014-12-09 14:21:59

标签: node.js cloudfoundry child-process

我有一个node.js应用程序,我想使用下面列出的代码生成子进程。

当我在本地运行此应用程序时,每个'ps'命令都会很好地触发关闭和退出事件。然而,在我们的云代工厂(pivotal.io)应用程序中,触发了stdout.close,但子进程的“关闭”和“退出”事件本身从未发生过。此外,进程仍然作为内存中的僵尸进程(因此在~500请求之后服务器因E_SPAWN错误而死亡)。因此,似乎永远不会触发node.js进程句柄中的退出处理程序,从而导致未读取子进程的退出代码。

这可能与容器监狱长,cgroups ......有关吗?有没有人为此解决问题或至少遇到同样的问题?

测试代码:

var cp = require('child_process');

//..create express app

app.get('/foo/', function(req, res, next) {
    var child = cp.spawn("ps",["aux"]);
    child.stderr.pipe(process.stderr);

    child.stdout.on('data', function(data) {
        console.log('data');
        res.send("\n<br>OUT" + data.toString());
    });

    child.stdout.on('close', function() {
        console.log('close stdout');
        res.send("\n<br>CLOSE STDOUT");
    });

    child.on('close', function() {
        console.log('close');
        res.send("\n<br>CLOSE");
    });

    child.on('exit', function() {
        console.log('exit');
        res.send("\n<br>EXIT");
    });
});

app.listen();

示例ps aux输出:

<br>OUTUSER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.0   1124   308 ?        S<s  14:15   0:00 wshd: 189gaonkujh    
vcap        31  0.2  0.0 602676 21692 ?        S<sl 14:15   0:00 node index.js 1234
vcap        33  0.0  0.0      0     0 ?        Z<   14:17   0:00 [ps] <defunct>
vcap        34  0.0  0.0  15332  1172 ?        R<   14:17   0:00 ps aux

更新

请参阅注释以获取解决方法:使用以“true;”开头的自定义启动命令,例如cf push myapp -c 'true;node index.js'

1 个答案:

答案 0 :(得分:1)

你没有杀死你的孩子进程,所以他们像僵尸一样被淘汰。通过杀死你的孩子杀死你的僵尸(是的,听起来很奇怪)..

child.on('exit', function() {
    console.log('exit');
    res.send("\n<br>EXIT");
    child.kill();
});
相关问题