我正在运行一个带有mongo连接池的守护进程。它运行良好几天但最终崩溃,每个后续请求都会收到此错误:
MongoError:服务器实例池被销毁
代码与此类似:
var MongoClient = require('mongodb').MongoClient;
var express = require('express');
var app = express();
MongoClient.connect(config.mongo.url, function(err, db) {
app.use('/', function(req, res, next) {
db.collection('somecollection').find({}).toArray(function(err, result) {
console.log(result);
});
})
var server = require('http').Server(app);
server.listen(config.worker.port, function() {
var address = server.address();
logger.info({
address: address.address,
port: address.port
}, 'New Worker created');
});
});
重新启动该过程可以解决问题,但我希望应用程序以某种方式优雅地重新连接并重置“db”对象。
答案 0 :(得分:3)
这就是我们正在使用的 - 如果连接失败,它会在5秒后尝试重新连接。它是为mongoose编写的,但我们只是在检测到错误时重新运行连接,这应该针对任何框架进行。
// Connect to mongodb
const connect = function () {
const options = {server: {socketOptions: {keepAlive: 1}}};
mongoose.connect(config.db, options);
};
connect();
mongoose.connection.on('error', err => {
let stack;
if (err) {
stack = err.stack;
}
winston.error('Mongo crashed with error', {err, stack});
}); // eslint-disable-line no-console
mongoose.connection.on('disconnected', () => {
setTimeout(connect, 5000);
});