Загрузка файла зависает от производственного кода, но работает локально - multer, node.js
Я работаю над приложением, которое было написано в Express 3, теперь мы обновили до Express 4, и у меня проблема с загрузкой файлов. Все работает на моем локальном компьютере Mac OSX, но не работает на производственном сервере в Ubuntu.
Я загружаю ZIP-файлы, с PNG и PSD внутри.
Я загружаю файл по многочастной форме: с промежуточным программным обеспечением.
Локально все в порядке, но в производственной среде связь обрывается. Файл начинает загружаться в основной корень загрузки, но как часть чанка, например, я загружаю zip-файл размером 50 МБ, но загруженный файл занимает около 30 КБ, и соединение разрывается, потому что событие onFileDataupload, загружающее данные в виде чанков, было прервано.
настройки в app.js
Настройки парсера моего тела:
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }) );
мои настройки мультера:
app.use(multer({
dest: './upload',
limits: {
fieldNameSize: 500,
files: 2,
fields: 20,
fileSize: 200 * 1024 * 1024
},
rename: function (fieldname, filename) {
return fieldname + filename + Date.now();
},
onFileUploadStart: function (file) {
console.log('Upload starting for filename: ' + file.originalname);
},
onFileUploadData: function (file, data) {
// console.log(data.length + ' of ' + file.fieldname + ' arrived')
},
onParseStart: function () {
console.log('Form parsing started at: ', new Date())
},
onParseEnd: function (req, next) {
console.log('Form parsing completed at: ', new Date());
// usage example: custom body parse
//req.body = require('qs').parse(req.body);
// call the next middleware
next();
},
onFileUploadComplete: function (file) {
console.log(file.fieldname + ' uploaded to ' + file.path);
},
onFileSizeLimit: function (file) {
console.log('Failed: ', file.originalname)
fs.unlink('./' + file.path) // delete the partially written file
},
onFilesLimit: function () {
console.log('Crossed file limit!')
},
onFieldsLimit: function () {
console.log('Crossed fields limit!')
},
onPartsLimit: function () {
console.log('Crossed parts limit!')
},
onError: function(error, next) {
console.log("Error occurred while uploading the file!!");
next(error);
}
}));
Я попробовал также грозный как альтернатива, и у меня та же проблема, работает локально, не работает на производственной среде. И я думаю, что это может быть проблемой с запросами, управляемыми узлом. В производственной среде мы используем pm2. Сглаживание разрывает соединение при загрузке файла.
У кого-нибудь была maby похожая проблема и нашли решение? Спасибо
1 ответ
Вероятно, у вас есть pm2 с включенной опцией "watch"; и загружать файлы внутри просматриваемого каталога. Затем pm2 перезапускает приложение каждый раз, когда вы начинаете писать новые файлы (из-за перезагрузки кода).
Чтобы проверить, решает ли это вашу проблему, просто удалите "watch": true из jour process.json или удалите флаг --wath из командной строки. Если это работает, прочитайте о pm2 watch, игнорируя здесь: https://github.com/Unitech/PM2/blob/master/ADVANCED_README.md#watch--restart, и настройте его правильно для своего приложения env &.