【发布时间】:2013-09-12 00:55:01
【问题描述】:
如何在大项目中组织Mongodb native-driver?
目前我在每个“模型”中使用此代码,这基本上只是模块中的一个对象。
users.js
var mongo = require('mongodb');
var Users = {};
Users.db = new mongo.Db(...);
Users.db.open = function(e, c){
if(e){ throw new Error(e); } else {
console.log('connection opened'); }
};
Users.c = Users.db.collection('users');
Users.login = function(username, rawPassword, callback){
Users.c.findOne({ username: username }, function(e, o){
if(o.password === encrypt(rawPassword)){ callback(o); }
else { callback(null); }
});
};
但这是否是在每个分离的模型中打开数据库连接的最佳方式?如何正确共享模型之间的连接?这是一个很好的解决方案吗:
database-connections.js
var mongo = require('mongodb');
var RedisClient = require('redis-client');
module.exports = {
main: new mongo.Db(...),
log: new mongo.Db(...),
cache: new RedisClient(...)
};
所以每次我们使用数据库连接时,我们都可以使用它:
users.js
var mainDb = require('database-connections.js').main;
var logDb = require('database-connections.js').log;
var cacheDb = require('database-connections.js').cache;
mainDb.open(function(e, c)){
if(e){ throw new Error(e); } else {
mainDb.collection('users', function(e, c){
// do work.
});
}
});
【问题讨论】:
标签: javascript node.js mongodb