node.js: запрос прерван в IncomingMessage.onReqAborted multiparty в фреймворке sails.js
У меня есть система загрузки файлов в node.js с многопартийным пакетом
var gm = require('gm').subClass({imageMagick: true});
var multiparty = require('multiparty');
var form = new multiparty.Form();
var s3 = sails.config.aws.main();
var options = {
partSize: 5242880, queueSize: 1
}
form.parse(req, function(err, fields, files) {
gm(files.fileToUpload[0].path)
.resize(200,200,'^')
.stream(function (err,buffer) {
s3.upload({
Bucket:'mybucket',
Body:buffer,
Key:'artwork-croppedimages/test.jpg'
},options,function(err, data) {
console.log("upload error",err);
console.log("data",data);
});
})
});
Он работает нормально, но при загрузке больших файлов, как правило, больше, чем 20 МБ, я получил эту ошибку
Error: Request aborted
at IncomingMessage.onReqAborted (/var/www/node/cushbuart/node_modules/multiparty/index.js:183:17)
at emitNone (events.js:86:13)
at IncomingMessage.emit (events.js:188:7)
at abortIncoming (_http_server.js:381:9)
at socketOnClose (_http_server.js:375:3)
at emitOne (events.js:101:20)
at Socket.emit (events.js:191:7)
at TCP._handle.close [as _onclose] (net.js:511:12)
Я знаю, что это решено с увеличением тайм-аута, но я не знаю, как в фреймворке sails.js
1 ответ
Решение
Тайм-аут запроса является функцией Node.js; в этом нет ничего специфического для паруса. Из документации Node.js:
request.setTimeout (timeout [, callback])
Добавлено в: v0.5.9
timeout
<number>
Миллисекунды до истечения срока ожидания запроса.callback
<Function>
Необязательная функция, вызываемая по истечении времени ожидания. То же, что и привязка к событию тайм-аута.Как только сокет назначен этому запросу и подключен, будет вызван socket.setTimeout().
Так что в вашем действии Sails.js, сделайте req.setTimeout(4 * 60 * 1000)
если вы хотите увеличить время ожидания до 4 минут.
Вы также можете использовать встроенные возможности загрузки файлов в Sails!