使用管道节点请求

时间:2016-04-20 22:56:53

标签: json node.js request openstreetmap overpass-api

我使用以下代码进行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} (毫秒)。我还能做些什么来阻止超时并获得适当的响应?我对这来自哪里感到有点困惑。

1 个答案:

答案 0 :(得分:2)

这是一个已知问题,尚未在Overpass API服务器上解决/修复。

有关详细信息,请参阅此Github问题:https://github.com/drolbr/Overpass-API/issues/220