【问题标题】:NodeJS process.spawn - exit event not firingNodeJS process.spawn - 退出事件未触发
【发布时间】:2015-06-09 01:17:27
【问题描述】:

我正在尝试使用 nodejs 进程生成。但不知何故,我无法让它发挥作用。我使用节点 v0.12.2。 “gulp do-something”被执行,我确实通过标准输出看到了输出......但退出事件永远不会被执行!

var task = spawn('gulp', [
      'do-something'
], {
        cwd: configs.workingDirectory
});

task.stdout.on('data', function(data){
      console.log(data.toString());
});

task.stderr.on('data', function (data) {
        console.log(data.toString());
});

task.on('exit', function (exitCode) {
        console.log("process.exitCode", exitCode)
});

当我尝试将 spawn 与 stdio 一起使用时:['ipc']

var task = spawn('gulp', [
          'do-something'
    ], {
            cwd: configs.workingDirectory,
            stdio: ['ipc']
    });

退出事件被触发,但在错误发生后:

gulp: ../deps/uv/src/unix/core.c:833: uv__io_stop: Assertion `loop->watchers[w->fd] == w' failed.

我尝试了 stdio 的其他组合。它会导致 task.stdout 和 task.sterr 为 null 或退出事件不被触发..

【问题讨论】:

  • close 会被发射吗?
  • @mscdex 不,它没有。
  • 好的。我设法让它工作使用:stdio: [0, 'pipe', 'pipe']
  • 您也可以尝试使用您的原始代码 task.stdin.end();

标签: node.js


【解决方案1】:

设置stdio: [0, 'pipe', 'pipe']解决了问题!!

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-02-26
    • 2017-05-09
    • 1970-01-01
    • 2021-07-21
    • 2014-08-23
    相关资源
    最近更新 更多