504网关超时节点+express+postgresql



我使用node+express作为后端,使用postgresql作为数据库,使用EJS作为前端。

我正在使用服务器启动/停止/日志的pm2包。

有时API查询错误意味着服务器在获得504网关超时错误的1/2分钟后没有响应。

示例:我正在访问http://mysiteurl/index这个页面中的url我有一些错误或异常,我试图连接另一个页面http://mysiteurl/about,此页面还得到错误:504网关超时

有时在/索引调用中出错

错误详细信息:

{ [error: invalid input syntax for integer: "undefined"] 
 name: 'error', 
 severity: 'ERROR', 
 code: '22P02', 
 detail: undefined, 
 hint: undefined, 
 position: '87', 
 internalPosition: undefined, 
 internalQuery: undefined, 
 where: undefined, 
 file: 'numutils.c', 
 line: '62', 
 routine: 'pg_atoi' } 

例如,这里我的代码/索引和/关于页面代码:

router.get('/index', function(req, res) {
    globaldetails.video(userId, function(err, videoList) {
        users.getUserDetails(userId, function(err, userDetails) {
            globaldetails.expertContent(userId, function(err, expertContent) {
                res.render('users/index', {
                    video : videoList.rows,
                    userDetails : userDetails.rows,
                    expertContent : expertContent.rows,
                });
            });
        });
    });
});
router.get('/about', function(req, res) {
    res.render('users/about');
});
function video(userId, callback) {
    client.query("select * from video where userId='" + userId + "' ", function(err, video) {
        console.log(err);
        callback(err, video);
    });
}
function getUserDetails(userId, callback) {
    var query = "select * from users where userId='" + userId + "' ";
    console.log(query);
    client.query(query, function(err, result) {
        if (err) {
            console.log(err);
        } else {
            callback(err, result);
        }
    });
}
function expertContent(userId, callback) {
    var query = "select * from content where userId='" + userId + "' ";
    client.query(query, function(err, expertContent) {
        if (err) {
            console.log(err);
        } else {
            callback(err, result);
        }
    });
}

任何人都可以帮忙。

预期结果:当我得到错误/index-api调用时,它应该不会影响/page-api调用。

此处的问题可能是userId为undefined,请将其记录以进行检查。你的应用程序中没有错误处理程序,它会使你的应用冻结

router.get('/index', function(req, res,next) {
  globaldetails.video(userId, function(err, videoList) {
    if(err) next(err); // do same things will other callback or change your code to Promise to easy debug
    else {
    users.getUserDetails(userId, function(err, userDetails) {
        globaldetails.expertContent(userId, function(err, expertContent) {
            res.render('users/index', {
                video : videoList.rows,
                userDetails : userDetails.rows,
                expertContent : expertContent.rows,
            });
        });
    });}
});
});

您还需要逻辑处理所有错误

app.use(function (err, req, res, next) {
    res.render(error page with err info)
})

最新更新