【问题标题】:Get stdout from subprocess of subprocess从子进程的子进程中获取标准输出
【发布时间】:2016-11-17 14:39:09
【问题描述】:

我正在 Node 中编写一个应用程序来自动创建 VPN 隧道,并尝试从命令 ipsec auto --add MyConnection(下面的生成代码)中获取标准输出,但似乎该命令实际上执行了多个子进程,其中一个会产生我需要的标准输出。有没有办法将此输出拉入 Node 中?

进程树:

  • 18242 - node server.js
    • 18264 - /usr/lib/ipsec/auto --up MyConnection(这是从 Node 运行的唯一命令)
      • 18266 - /usr/lib/ipsec/auto --up MyConnection
        • 18268 - sh
          • 18271 - /usr/lib/ipsec/whack --name MyConnection --initiate
        • 18269 - `awk /^= / { exit $2 } $1 != "002" { print }

我的节点代码:

...
var spawn = require('child_process').spawn;
var Hapi = require('hapi');
var server = new Hapi.Server();
server.register(Inert, function(err) {
    if (err) throw err;
});
var io = require('socket.io')(server.listener);
...
function start(file, route, socket) {
    ...
    var connect = spawn('ipsec' ['auto', '--up', file], {env: Object.create(process.env)});
    connect.stdout.on("data", function(out) {
        socket.emit('connect-out', out);
    });
    connect.stderr.on("data", function(out) {
        socket.emit('connect-out', out);
    });
    connect.on('exit', function(code) {
         ...
    });
}

【问题讨论】:

    标签: node.js linux vpn


    【解决方案1】:

    我发现程序在程序终止之前不会刷新缓冲区,所以我使用命令stdbuf --output=0 ipsec auto --add MyConnection 强制在每次写入时刷新缓冲区,而不是在执行结束时刷新。

    【讨论】:

      最近更新 更多