sql >> Databasteknik >  >> NoSQL >> MongoDB

Promise och nodejs MongoDB-drivrutin

Att manuellt lova ett API är farligt, jag föreslår något i stil med:

TaskBroker.prototype._connectMongo = Q.nfcall(MongoClient.connect,
                                             'mongodb://127.0.0.1:27017/test',
                                            {});
TaskBroker.prototype.connectMongo = function(){
   return this._connectMongo().then(function(db){
       console.log("Hello");
       // self.stuff...
       return 42;
   }).catch(function(e){
       console.err("connection error",e); // log the connection error, or handler err
       throw e; // don't mark as handled, propagate the error.
   });
};

Med Bluebird-löften skulle det se ut ungefär så här:

var MongoClient = Promise.promisifyAll(require("mongodb").MongoClient);

TaskBroker.prototype.connectMongo = function(){
    return MongoClient.connectAsync().then(... 
        // Bluebird will automatically track unhandled errors        
};


  1. Initiera data på dockeriserade mongo

  2. Vilken SchemaType i Mongoose är bäst för tidsstämpel?

  3. Varför en 500MB Redis dump.rdb-fil tar ungefär 5,0GB minne?

  4. Ändra inställning av TTL på hSet Keys