如何在node + express中重新运行请求处理程序?

时间:2012-08-31 14:00:23

标签: javascript node.js mongodb express node-mongodb-native

我正在运行node + express + mongojs。以下是示例代码:

function mongoCallback(req, res) {
  "use strict";
  return function (err, o) {
    if (err) {
      res.send(500, err.message);
    } else if (!o) {
      res.send(404);
    } else {
      res.send(o);
    }
  };
}

var express, app, params, mongo, db;

express = require('express');
params = require('express-params');
app = express();
params.extend(app);

app.use("/", express.static('web'));

mongo = require('mongojs');

db = mongo.connect('mydb', ['inventory']);

app.get('/api/inventory', function (req, res) {
  db.inventory.find(mongoCallback(req, res));
});

app.listen(8000);
console.log('Listening on port 8000');

有时候我忘了运行mongod,并且尝试与数据库通信失败并显示“无法连接到...”错误。问题是启动mongod是不够的,已经存在的db对象似乎记得无法建立连接,因此即使mongod已经在运行,服务器也会继续失败。

所以,我提出了以下解决方案:

var express, app, params, mongo, db, api;

if (!String.prototype.startsWith) {
  String.prototype.startsWith = function (str) {
    "use strict";
    return this.lastIndexOf(str, 0) === 0;
  };
}

function setDB() {
  db = mongo.connect('IF', ['invoices', 'const', 'inventory']);
}

function mongoCallback(req, res, next, caller, secondTry) {
  return function (err, o) {
    if (err) {
      if (!secondTry && err.message && err.message.startsWith("failed to connect to")) {
        setDB();
        caller(req, res, next, true);
      } else {
        res.send(500, err.message);
      }
    } else if (!o) {
      res.send(404);
    } else {
      res.send(o);
    }
  };
}

express = require('express');
params = require('express-params');
app = express();
params.extend(app);

app.use("/", express["static"]('web'));

mongo = require('mongojs');

setDB();

api = {
  getInventory: function (req, res, next, secondTry) {
    db.inventory.find(mongoCallback(req, res, next, api.getInventory, secondTry));
  }
};

app.get('/api/inventory', api.getInventory);

app.listen(8000);
console.log('Listening on port 8000');

如果请求因“连接失败”错误而重新运行请求,它基本上会重新创建db对象。这仅在第一次失败时完成。后续失败将返回错误。

我根本不喜欢我的解决方案。一定有更好的方法。有什么建议吗?

感谢。

2 个答案:

答案 0 :(得分:2)

你的意思是“现有的db对象似乎记得没有连接”?如果您在运行mongod之前启动Express应用程序,那么您的意思是数据库上的查询失败了吗?由于您在快速应用程序启动时连接到数据库,因此应首先运行mongod。

如果您担心数据库在初始连接后出现故障并导致CRUD操作失败,您可以检查操作中的错误

db.inventory.find(function(err, docs) {
    // check err to see if there was a connection issue
});

然后在出现错误时重新连接。

答案 1 :(得分:0)

据我所知,mongodb原生驱动程序允许设置{ auto_reconnect:true },你试过设置吗?

如果数据库根本没有运行,我不确定这是怎么回事,mongoose.js例如缓存所有请求,直到数据库准备好并在成功连接后发出它们。