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

Como verificar se a conexão do MongoDB está ativa no Node.js


Você pode usar event para tratá-lo como callback.
E talvez tenha sua variável global que identificará que ela não está conectada.

Você pode ter db.js separado arquivo, que se comportará como módulo. E você pode ter uma função para obter a coleção dele.
var mongodb = require('mongodb');
var client;
var collections = { };

new mongodb.Db( ... ).open((function (err, c) {
  if (!err) {
    client = c;
    client.on('close', function() {
      client = null; // clear client
      collections = { }; // clear old collections
      // connection closed
    });
  } else {
    // error connecting
  }
});

// get collection
exports.get = function(name, callback) {
  if (client) {
    if (!collections[name]) {
      collections[name] = new mongodb.Collection(client, name);
    }
    callback(null, collections[name]);
  } else {
    // can perform reconnecting and then get collection and call callback
    callback(new Error('not connected'));
  }
}

Então para usar:
var db = require('./db.js');

db.get('users', function(err, collection) {
  if (!err) {
    collection.find({ ...
  } else {
    console.log(err);
  }
});

Desculpe, acabei de notar que você está usando o Mongoose, que pode ser um pouco diferente.