【发布时间】:2016-02-02 09:35:57
【问题描述】:
我遇到了子进程模块的问题,特别是 child.spawn 和 child.fork。 我依赖 child_process.fork 的文档,其中说:
这是 child_process.spawn() 功能的一个特例 产生 Node.js 进程。除了将所有方法放在一个 普通的 ChildProcess 实例,返回的对象有通信 通道内置。有关详细信息,请参见 child.send(message, [sendHandle])。
我在下面简化了我的问题:
parent.js 是:
var cp = require('child_process');
var n = cp.fork('./child.js');
n.send({a:1});
//n.stdout.on('data',function (data) {console.log(data);});
n.on('message', function(m) {
console.log("Received object in parent:");
console.log( m);
});
child.js 是:
process.on('message', function(myObj) {
console.log('myObj received in child:');
console.log(myObj);
myObj.a="Changed value";
process.send(myObj);
});
process.stdout.write("Msg from child");
正如预期的那样。输出是:
Msg from child
myObj received in child:
{ a: 1 }
Received object in parent:
{ a: 'Changed value' }
我希望它与 parent.js 中未注释的注释行一起使用。换句话说,我想在父进程的 n.stdout.on('data'... 语句中捕获子进程中的标准输出。如果我取消注释它,我会收到错误:
n.stdout.on('data',function (data) {console.log(data);});
^
TypeError: Cannot read property 'on' of null
我不介意使用任何子进程异步变体、exec、fork 或 spawn。有什么建议吗?
【问题讨论】:
-
有人可以解释一下 - 为什么在流式传输...数据时更喜欢
message侦听器而不是data?
标签: node.js fork child-process spawn