我正在使用express.js构建一个node.JS应用程序,它基本上是SQL Server中进程的桥梁。
所以我有这个路由器:
router.get('/runpr/:ref', function(req, res, next) {
var p1 = req.params.ref;
execSQLQuery("EXEC SP_PROCESSA_PREMIO "+p1, function(result, err) {
var response = '';
if ( err != null ) {
// change error to node errors
response = [{
A_STATUS: 0,
MSG: err.originalError.info.message,
FINISHED: new Date(Date.now())
}];
} else {
response = result.recordset;
}
res.json( response );
});
})
调用函数execSQLQuery:
function execSQLQuery(sqlQry, callback) {
var request = new sql.Request();
request.query(sqlQry, function(err, recordset) {
callback(recordset, err);
});
}
SQL连接适用于其他查询,但是这个特定的PROCEDURE是从节点调用的,它需要3分钟,或多或少。该过程总是返回一个包含SQL错误或成功结果的数据集。但在这种情况下,当我浏览到路由器时,需要一些时间才能返回错误ERR_EMPTY_RESPONSE。
当我检查SQL Server时,程序仍在运行,我假设有一个 mssql-node timeout ,所以我设置了:>
var config = {
user: 'xxxx',
password: 'xxx',
server: 'xxxx',
database: 'xxxx',
connectionTimeout: 500000,
requestTimeout: 500000
}
此外,节点本身 :
// listen and timeout
var server = app.listen(app.get('port'))
server.timeout = 500000;
他们都没有解决问题......
答案 0 :(得分:0)
刚刚找到答案。我在下面设置配置
// listen and timeout
var server = app.listen(app.get('port'))
server.timeout = 500000;
在我的app.js文件中,这是错误的......
由于我使用express.js运行它,您应该添加以下行
server.timeout = 500000;
在' www' bin文件夹中的文件。