gpt4 book ai didi

javascript - mongoose 和 nodejs 的 mongodb 连接超时错误

转载 作者:可可西里 更新时间:2023-11-01 09:11:13 29 4
gpt4 key购买 nike

我迫切需要一些帮助。我正在尝试使用 mongoose 和 nodeJS 将大文件 (8 GB) 上传到 gridfs。但是由于文件很大,上传需要一些时间。过了一会儿,我收到以下错误:

home/user/FileUpload/node_modules/mongodb/lib/utils.js:98
process.nextTick(function() { throw err; });
^
MongoError: connection 0 to 127.0.0.1:27017 timed out
at Function.MongoError.create (/home/user/FileUpload/node_modules/mongodb-core/lib/error.js:29:11)
at Socket.<anonymous> (/home/user/FileUpload/node_modules/mongodb-core/lib/connection/connection.js:186:20)
at Object.onceWrapper (events.js:314:30)
at emitNone (events.js:105:13)
at Socket.emit (events.js:207:7)
at Socket._onTimeout (net.js:402:8)
at ontimeout (timers.js:488:11)
at tryOnTimeout (timers.js:323:5)
at Timer.listOnTimeout (timers.js:283:5)

我已尝试通过增加 connectTimeoutMS 来解决此问题,但错误仍然存​​在。我正在使用 MongoDB 3.4.5 mongoose 4.8.4 nodejs 8.1.4 和 npm 5.0.3。

以下是app.js:

var mongoose = require('mongoose');
var schema = mongoose.schema;
mongoose.connect('mongodb://127.0.0.1/gridFS'),{
server: {
socketOptions: {
socketTimeoutMS: 3000000,
connectionTimeoutMS: 3000000,
keepAlive:3000000
}
},

replset: {
socketOptions: {
keepAlive: 3000000,
connectTimeoutMS: 3000000
}
}
};
var conn = mongoose.connection;
var path = require('path');
var Grid = require('gridfs-stream');
var fs = require('fs');
var videoPath = path.join(__dirname, 'readFrom/bio seq test1.txt');
Grid.mongo = mongoose.mongo;
conn.once('open', function(){

console.log('- connection open -');
var gfs = Grid(conn.db);

var writestream = gfs.createWriteStream({

filename: 'bio seq test 1'
});

fs.createReadStream(videoPath).pipe(writestream);
writestream.on('close', function(file){
console.log(file.filename + 'Written to DB');
});
});

package.json文件如下:

{
"name": "file-upload-gridfs",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo '' &amp;&amp; exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {
"body-parser": "^1.16.1",
"cookie-parser": "^1.4.3",
"express": "^4.14.1",
"gridfs-stream": "^1.1.1",
"mongoose": "^4.8.4",
"morgan": "^1.8.2",
"multer": "1.3.0",
"multer-gridfs-storage": "1.0.0",
"path.join": "^1.0.0",
"serve-favicon": "^2.4.3"
}
}

最佳答案

好的。我使用这个非常有用的讨论解决了这个问题。MongoDB 的默认套接字连接时间是 30 秒。如果任何查询/操作花费的时间超过此时间,则连接将中止并发生连接超时错误。通过此更改,我能够将 32GB 的文件上传到 GridFS,而不会出现任何中断。

https://github.com/Automattic/mongoose/issues/4789

我通过以下方式传递超时参数。

server: {
socketOptions: {
socketTimeoutMS: 3000000,
connectionTimeoutMS: 3000000,
keepAlive:3000000
}
},

replset: {
socketOptions: {
keepAlive: 3000000,
connectTimeoutMS: 3000000
}
}
};

但需要按如下方式设置:

const serverOptions = {
poolSize: 100,
socketOptions: {
socketTimeoutMS: 6000000
}
};

mongoose.createConnection(dbpath, {
server: serverOptions,
replset: serverOptions //if you are using replication
});

在我的例子中,我使用了 localhost。

const serverOptions = {
poolsize:100 ,
socketOptions:{
socketTimeoutMS: 6000000
}
};
var mongodbUri = 'mongodb://localhost:27017/gridFS';
mongoose.connect(mongodbUri, {
server: serverOptions
});

希望这对遇到类似问题的人有所帮助。

关于javascript - mongoose 和 nodejs 的 mongodb 连接超时错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45089357/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com