Проблема буфера Stdout с использованием дочернего процесса узла


Я пытаюсь выполнить curl с помощью узла child_process, чтобы получить файл JSON (около 220Ko) из общей папки в локальной сети. Но на самом деле он возвращает проблему буфера, которую я не могу преодолеть. Вот мой код:

var exec = require('child_process').exec;

var execute = function(command, callback){
    exec(command, function(error, stdout, stderr){ callback(error, stdout); });
};

execute("curl http://" + ip + "/file.json", function(err, json, outerr) {
    if(err) throw err;
    console.log(json);
})

и вот ошибка, которую я получаю:

if(err) throw err;
          ^
Error: stdout maxBuffer exceeded.
    at Socket.<anonymous> (child_process.js:678:13)
    at Socket.EventEmitter.emit (events.js:95:17)
    at Socket.<anonymous> (_stream_readable.js:746:14)
    at Socket.EventEmitter.emit (events.js:92:17)
    at emitReadable_ (_stream_readable.js:408:10)
    at emitReadable (_stream_readable.js:404:5)
    at readableAddChunk (_stream_readable.js:165:9)
    at Socket.Readable.push (_stream_readable.js:127:10)
    at Pipe.onread (net.js:526:21)
2 53

2 ответа:

вы должны использовать и установить при использовании child_process.exec. Из документация:

maxBuffer указывает наибольшее количество данных, разрешенных для stdout или stderr - если это значение превышено, то дочерний процесс убивается.

в документации также указано, что значение по умолчанию maxBuffer такое 200кб.

в качестве примера, максимальный размер буфера увеличивается до 500 КБ в следующем код:

var execute = function(command, callback){
    exec(command, {maxBuffer: 1024 * 500}, function(error, stdout, stderr){ callback(error, stdout); });
};

кроме того, вы можете прочитать о http.get чтобы увидеть, если он может достичь того, что вы пытаетесь сделать.

У меня была аналогичная проблема, и я исправил ее переход от exec к spawn:

var child = process.spawn('<process>', [<arg1>, <arg2>]);

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

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

child.on('close', function (code) {
    console.log('child process exited with code ' + code);
});