将输入数据发送到node.js中的子进程

时间:2014-11-20 22:50:37

标签: javascript c++ node.js online-compilation

我正在编写代码以在node.js环境中创建在线c ++编译器。使用spawn函数我创建了一个子进程,它将编译代码并执行它并将输出发送回用户。 但我需要将输入发送到正在运行的c ++程序。我用了child.stdin.write('data'); 用于向子节点发送数据,但我认为程序中的cin没有收到输入。
请帮我发送输入到正在运行的c ++代码 感谢。

2 个答案:

答案 0 :(得分:2)

如果你想传递消息,你可能应该使用集群或分叉......如果这样做,节点将设置IPC,以便你能够通过process.send进行通信


或者,您可以将pub / sub系统用于通信渠道(Redis适用于此),如果您需要跨服务器进行通信,这也是您最好的选择。


以下是旧工作脚本的示例...

var env = process.env.NODE_ENV || 'dev';
var cluster = require("cluster");

//TODO: need to adjust to use domains for this work
process.on('uncaughtException', function (err) {
  console.error('GENERAL EXCEPTION IN %s: %s', process.env.WORKER_TYPE || 'MASTER',err);
  if (err.stack) console.error(err.stack);
  if (cluster.isWorker) {
    //process.send notifies the parent process of the error
    process.send({
      err: {
        "str": err && err.toString() || "unknown error"
        ,"message": err && err.message || null
        ,"stack": err && err.stack || null
      }
    });
  }
  process.nextTick(function(){
    process.exit(666);
  });
});


if (cluster.isMaster) startMaster();
if (cluster.isWorker) startWorker();

function startMaster() {
  createWorker("foo");
  createWorker("bar");
}

function createWorker(workerType) {
  var worker = cluster.fork({"WORKER_TYPE":workerType}); //passes environment variables to child
  worker.on('online',onOnline.bind(null, worker));
  worker.on('message',onMessage.bind(null, worker)); 
  worker.on('exit',onExit.bind(null, worker));
  worker.workerType = workerType;
  return worker; 
  // you can use worker.send() to send a message that 
  // will raise a message event in the child
}

function startWorker() {
  console.log("Running Worker: %s %s", cluster.worker.id, process.env.WORKER_TYPE);
  setTimeout(process.exit.bind(process,0), 5000); //close in 5 seconds
  //you may want to load a specific module based on WORKER_TYPE
}

function onOnline(worker) {
  console.log("Worker Online: %s %s", worker.id, worker.workerType);
  //console.log(arguments);
}

function onMessage(worker, msg) {
  if (msg.err) {
    console.warn("Error From", worker.id, worker.workerType, msg.err);
  } else {
    console.log("Message From", worker.id, worker.workerType);
  }
  //console.log(arguments);
}

function onExit(worker, code, signal) {
  console.log("Worker Exited: %s %s %s %s", worker.id, worker.workerType, code, signal);

    if (env == 'dev') {
        //for now just exit the whole thing (dev mode)
        process.nextTick(function(){
            process.exit(1);
        });
    } else {
        //workers should simply keep working...
        //fire off a new worker
        createWorker(worker.workerType);
    }

}

答案 1 :(得分:2)

1.使用输入数据创建文件 2.创建一个ReadStream开放输入文件 3.使用ReadStreamchildprocess.stdin打包。

file=fs.createReadStream('input.txt',{encoding:'utf8'});
file.pipe(childprocess.stdin);

这对我有用。