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!

Другие вопросы по тегам