36

这对我来说有点不清楚(我刚刚开始使用 Node 和 Mongo),由于服务器性能和压力(我想这是另一个问题,但我会在帖子的结尾)。

因此,假设我正在使用 Node.js 和 Restify 编写 API,其中每个 API 端点对应一个函数,我应该:

a)打开数据库连接并将其存储在全局变量中,然后在每个函数中使用它?
例子:

// requires and so on leave me with a db var, assume {auto_reconnect: true}
function openDB() {
    db.open(function(err, db) {
        // skip err handling and so on
        return db;
    }
}

var myOpenDB = openDB(); // use myOpenDB in every other function I have

b)打开数据库连接,然后将所有东西都放在一个巨大的封闭中?
例子:

// same as above
db.open(function(err, db) {
    // do everything else here, for example:
    server.get('/api/dosomething', function doSomething(req, res, next) { // (server is an instance of a Restify server)
        // use the db object here and so on
    });
}

c)每次需要时打开和关闭数据库?
例子:

// again, same as above
server.get('/api/something', function doSomething(req, res, next) {
    db.open(function(err, db) {
        // do something
        db.close();
    });
});

server.post('/api/somethingelse', function doSomethingElse(req, res, next) {
    db.open(function(err, db) {
        // do something else
        db.close();
    });
});

最后一个是我出于直觉会做的,但同时我也觉得这样做不太舒服。它不会对 Mongo 服务器造成太大压力吗?尤其是当(我希望我确实做到了)它会收到数百个(如果不是数千个)这样的电话吗?

先感谢您。

4

2 回答 2

13

我非常喜欢MongoJS。它允许您以与默认命令行非常相似的方式使用 Mongo,它只是官方 Mongo 驱动程序的包装。您只需打开数据库一次并指定您将使用哪些集合。如果您使用--harmony-proxies.

var db = require('mongojs').connect('mydb', ['posts']);

server.get('/posts', function (req, res) {
  db.posts.find(function (err, posts) {
    res.send(JSON.stringify(posts));
  });
});
于 2012-08-03T18:40:20.770 回答
6
  • 选项 A 不是一个好主意,因为不能保证在处理 HTTP 请求之前数据库将完成打开(当然这不太可能)
  • 选项 C 也不理想,因为它不必要地打开和关闭数据库连接

我喜欢处理这个问题的方式是使用延迟/承诺。Node 有很多不同的 Promise 库,但基本思想是做这样的事情:

var promise = new Promise();

db.open(function(err, db) {
    // handle err
    promise.resolve(db);
});

server.get('/api/something', function doSomething(req, res, next) {
    promise.then(function(db)
        // do something
    });
});

我相信 Mongoose 处理连接的方式与此类似。

于 2012-08-03T17:54:56.967 回答