2

这是我的带有 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?

4

1 回答 1

1

现在我将 node.js 版本更新到最新版本 10.4,问题似乎不再发生,所以可能是因为旧的 node.js 版本无法与最新的 express 版本一起使用。

我总是更新库版本,但不更新 node.js。

于 2013-04-15T11:25:50.507 回答