sql >> Databáze >  >> NoSQL >> MongoDB

NodeJS - MongoDB:použijte otevírací připojení

Když require('somemodule') a poté jej znovu vyžadovat podruhé, použije JIŽ načtenou instanci. To vám umožní vytvořit singletony celkem snadno.

Tedy - uvnitř sharedmongo.js :

var mongo = require('mongodb');

// this variable will be used to hold the singleton connection
var mongoCollection = null;

var getMongoConnection = function(readyCallback) {

  if (mongoCollection) {
    readyCallback(null, mongoCollection);
    return;
  }

  // get the connection
  var server = new mongo.Server('127.0.0.1', 27017, {
    auto_reconnect: true
  });

  // get a handle on the database
  var db = new mongo.Db('squares', server);
  db.open(function(error, databaseConnection) {
    databaseConnection.createCollection('testCollection', function(error, collection) {

      if (!error) {
        mongoCollection = collection;
      }

      // now we have a connection
      if (readyCallback) readyCallback(error, mongoCollection);
    });
  });
};
module.exports = getMongoConnection;

Poté uvnitř a.js :

var getMongoConnection = require('./sharedmongo.js');
var b = require('./b.js');
module.exports = function (req, res) {
  getMongoConnection(function(error, connection){
    // you can use the Mongo connection inside of a here
    // pass control to b - you don't need to pass the mongo
    b(req, res);
  })
}

A uvnitř b.js :

var getMongoConnection = require('./sharedmongo.js');
module.exports = function (req, res) {
  getMongoConnection(function(error, connection){
    // do something else here
  })
}

Myšlenka je, když oba a.js a b.js zavolejte getMongoCollection , poprvé se připojí a podruhé vrátí již připojený. Tímto způsobem zajistíte, že používáte stejné připojení (zásuvku).




  1. Je možné zploštit dotaz na výsledek MongoDB?

  2. Možnost shody příkazu Redis scan nefunguje v Pythonu

  3. Existuje způsob, jak přinutit mongodb, aby uložil určitý index v paměti ram?

  4. Použití podmínky na více dokumentů pro stejné pole v MongoDB