MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Node.js e MongoDB, reutilizando o objeto DB


Você sempre pode escrever um módulo que inicialize suas conexões de banco de dados e as torne acessíveis em todo o seu programa. Por exemplo:

mongo.js
var mongodb = require('mongodb');

module.exports.init = function (callback) {
  var server = new mongodb.Server("127.0.0.1", 27017, {});
  new mongodb.Db('test', server, {w: 1}).open(function (error, client) {
    //export the client and maybe some collections as a shortcut
    module.exports.client = client;
    module.exports.myCollection = new mongodb.Collection(client, 'myCollection');
    callback(error);
  });
};

app.js
var mongo = require('./mongo.js');

//setup express...

//initialize the db connection
mongo.init(function (error) {
    if (error)
        throw error;

    app.listen(80); //database is initialized, ready to listen for connections
});

randomFile.js
var mongo = require('./mongo.js');

module.exports.doInsert = function () {
  //use the collection object exported by mongo.js
  mongo.myCollection.insert({test: 'obj'}, {safe:true}, function(err, objects) {
    if (err)
        console.warn(err.message);
  });
};

Eu sei que as pessoas falam sobre pooling, mas quando fiz o benchmarking de pooling de conexões mongo versus uma única conexão para todas as solicitações, a única conexão realmente teve um desempenho melhor. Concedido, isso foi há cerca de um ano, mas duvido que o conceito básico tenha mudado. Todas as requisições são assíncronas, então não é como se várias conexões fossem necessárias para fazer requisições simultâneas.

Quanto ao MongoClient, acho que essa é a nova sintaxe que eles estão incentivando. De qualquer forma, é essencialmente um cliente objeto que você deseja manter e tornar acessível, independentemente do estilo que você usa.