在序列化循环中运行示例代码时出错

时间:2013-01-26 01:07:12

标签: node.js

我一直在修改节点,在尝试学习child_process模块​​时遇到了一个问题。我试图将许多调用序列化为'ps -eF | grep ssh',但它崩溃了我的系统,下面的错误。所以有两个问题。首先,有没有更好的方法来做我没有图书馆的尝试?第二,为什么不工作:)

events.js:71
        throw arguments[1]; // Unhandled 'error' event
                       ^
Error: This socket is closed.
    at Socket._write (net.js:519:19)
    at Socket.write (net.js:511:15)
    at Socket.<anonymous> (/home/me/tmp/test.js:10:16)
    at Socket.EventEmitter.emit (events.js:96:17)
    at Pipe.onread (net.js:397:14)
function callpsgrep(callback) {
  var spawn = require('child_process').spawn,
      ps    = spawn('ls', ['-la']),
      grep  = spawn('grep', ['bananas']);

  ps.stdout.on('data', function (data) {
    grep.stdin.write(data);
  });

  ps.stderr.on('data', function (data) {
    console.log('ps stderr: ' + data);
  });

  ps.on('exit', function (code) {
    if (code !== 0) {
      console.log('ps process exited with code ' + code);
    }
    grep.stdin.end();
  });

  grep.stdout.on('data', function (data) {
    console.log('' + data);
  });

  grep.stderr.on('data', function (data) {
    console.log('grep stderr: ' + data);
  });

  grep.on('exit', function (code) {
    if (code !== 0) {
      console.log('grep process exited with code ' + code);
    }
    callback();
  });
}

function series(i) {
  if (i < 1000) {
    callpsgrep( function() {
      return series(i+1);
    });
  }
}
series(0);

1 个答案:

答案 0 :(得分:1)

关闭事件上关闭grep的标准输入,而不是退出事件。

ps.on('exit', function (code) {
  if (code !== 0) {
    console.log('ps process exited with code ' + code);
  }
});

ps.on('close', function (code) {
  grep.stdin.end();
});

虽然不是很好 documented 但我在帮助文件中阅读了以下内容。

事件:'退出'

请注意,子进程stdio流可能仍处于打开状态。

事件:'关闭'#

当子进程的stdio流全部终止时,将发出此事件。这与“退出”不同,因为多个进程可能共享相同的stdio流。