处理MongoError的好方法:服务器实例池被破坏了

时间:2016-11-09 14:36:19

标签: node.js mongodb

我正在运行一个带有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”对象。

1 个答案:

答案 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);
    });