Проблема буфера 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 ответа:
вы должны использовать и установить при использовании
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); });