2016-11-09 5 views
1

mongo接続プールでデーモンを実行しています。それは日のために細かい動作しますが、最終的にそれがクラッシュし、後続のすべての要求はこのエラーを取得します。MongoErrorの適切な処理方法:サーバーインスタンスプールが破損しました

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

これは私たちが使用しているものです。接続に失敗すると、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); 
    }); 
+1

標準のドライバでイベントを使って動作させるかどうかを試してみます。唯一の候補は次のようです:http://mongodb.github.io/node-mongodb-native/2.2/api/Db.html#event:error –

+0

@phraktalこのイベントを聞くことができましたか?私はドキュメントを見ても、ネイティブドライバのエラーを聞く方法はまだ理解できません。アドバイス、ありがとう:) – chaintng

関連する問題