我使用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)
})