我使用以下代码进行OpenStreetMap查询(overpass-API)。它适用于较小的查询,但在较大的查询上运行大约10分钟,它只生成504网关超时响应。
代码:
var reqStr = "http://overpass.osm.rambler.ru/cgi/interpreter?data=...
console.time("query");
var stream = request(reqStr,{timeout: 3600000}).on('error', function(err) {
console.log(err)
}).pipe(fs.createWriteStream('resultExport.json'));
stream.on('finish', function () {
console.timeEnd("query");
});
响应(resultExport.json):
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>504 Gateway Time-out</title>
</head><body>
<h1>Gateway Time-out</h1>
<p>The gateway did not receive a timely response
from the upstream server or application.</p>
</body></html>
查询命令有一个 [timeout:3600] (秒),请求得到 {timeout:3600000} (毫秒)。我还能做些什么来阻止超时并获得适当的响应?我对这来自哪里感到有点困惑。
答案 0 :(得分:2)
这是一个已知问题,尚未在Overpass API服务器上解决/修复。
有关详细信息,请参阅此Github问题:https://github.com/drolbr/Overpass-API/issues/220