这是我的带有 mongodb 的 node.js 应用程序,代码自爆运行良好,只需通过用户会话 id 从 mongodb 数据库加载用户信息,会话存储是来自connect-mongo的 MongoStore 。最初,这个 node.js 部署在我的计算机本地。
但是,当我单击浏览器以非常快地刷新页面时,在单击(20,30 次单击)后会抛出异常,说 未捕获的异常: RangeError:超出最大调用堆栈大小 ,有时,它还会显示另一个错误,说错误:connect-mongo 上没有打开的连接
app.get('/',homePage);
function homePage(req,res){
var locals = {};
userModel.findUserById(req.session.uid,function(err,user){
if(err) {
console.log('user uid not found'.red);
}
else{
console.log('find user uid'.green,user._id);
locals.user = {
username: user.username,
email: user.email
};
res.send(200);
}
})
}
这是userModel调用的findUserById,它在另一个文件中。
function findUserById(id,callback){
var id;
try {
id = mongoose.Types.ObjectId(id);
} catch(e) {
callback(err, null);
}
UserModel.findById(id,function(err, doc){
if(err){callback(err, null);}
else{
callback(null, doc);
}
})
}
我不知道真正出了什么问题,是connect-mongo还是其他什么,我发现超出最大调用堆栈大小的错误是因为递归,但是我在这里显示的代码没有递归。
更新:
app.get('/',homePage);
function homePage(req,res){
var locals = {};
res.send(200);
}
即使在这种情况下,多次快速点击后,服务器也会抛出Maximum call stack size exceeded的错误
我猜是因为我的 node.js 版本和 express 不够兼容?我的 express 版本是 3.1.0 但我的 node.js 版本是 0.8.20?