Lorsque vous require('somemodule')
et qu'il en redemande une seconde fois, il utilisera l'instance DÉJÀ chargée. Cela vous permet de créer des singletons assez facilement.
Donc - à l'intérieur de 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;
Puis à l'intérieur de 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);
})
}
Et à l'intérieur de b.js
:
var getMongoConnection = require('./sharedmongo.js');
module.exports = function (req, res) {
getMongoConnection(function(error, connection){
// do something else here
})
}
L'idée est lorsque les deux a.js
et b.js
appelez getMongoCollection
, la première fois qu'il se connectera, et la deuxième fois il renverra celui déjà connecté. De cette façon, il s'assure que vous utilisez la même connexion (socket).