2

我像下面这样连接到我的数据库:

var mongoClient = new MongoClient(new Server('localhost', 27017, {auto_reconnect: true}));
mongoClient.open(function (err, mongoClient) {
  var db = mongoClient.db('db_name');
  db.authenticate('user', 'password', function () {err, result} {
     if (err || !result) return console.log('error');

     app.use(express.session({       
        store: new MongoStore({
          db: db
        })
     });
  });
}); 

我想与 MongoStore 共享数据库连接,但它似乎不起作用。我该怎么做?

编辑:我在我的数据库上使用身份验证,但是在 new MongoStore() get 执行后,我收到以下错误:

not authorized for query on site.system.indexes
4

1 回答 1

5

这就是它对我的工作方式,

var connectionString = "mongodb://username:password@localhost:27017/db_name";
var dbOptions = {
server:{
    'auto_reconnect': true,
    'poolSize': 20,
    socketOptions: {keepAlive: 1}  
    }
}
// For long running applictions it is often prudent to enable keepAlive. Without it,
// after some period of time you may start to see "connection closed" errors for what 
// seems like no reason.
MongoClient.connect(connectionString, dbOptions, function(err, db) {
    if(err){
        console.log(err);            
    }

app.use(express.session({
        store:new mongoStore({db: db}),
        secret: 'secret'
    }));
})

这对我来说非常有效,它也不会给你未授权的问题。以前我们不需要提供 keepAlive 选项,它在没有它的情况下可以完美运行,但是随着 mongodb 2.4 的发布,我们需要为长时间运行的应用程序提供 keepAlive 选项,否则我们会不断关闭连接或出现未授权的错误。

于 2013-06-11T07:23:58.067 回答