Meteorを使用してサーバー側の2点間の距離と期間を見つけるためにグーグルを使用しています。正常に動作していましたが、突然次のエラーが発生しました。
Error: connect ETIMEDOUT at Object.Future.wait (/root/.meteor/packages/meteor-tool/.1.1.10.ki0ccv++os.linux.x86_64+web.browser+web.cordova/mt-os.linux.x86_64/dev_bundle/server-lib/node_modules/fibers/future.js:398:15)
at Object.call (packages/meteor/helpers.js:119:1)
at Object.HTTP.get (packages/http/httpcall_common.js:50:1)
at Object.calculateDistance (server/helper.js:351:1)
at [object Object].getDistance (server/methods.js:147:1)
at maybeAuditArgumentChecks (livedata_server.js:1698:12)
at livedata_server.js:708:19
at [object Object]._.extend.withValue (packages/meteor/dynamics_nodejs.js:56:1)
at livedata_server.js:706:40
at [object Object]._.extend.withValue (packages/meteor/dynamics_nodejs.js:56:1)
- - - - -
at errnoException (net.js:905:11)
at Object.afterConnect [as oncomplete] (net.js:896:19)
サーバー上の私のコードは次のとおりです。
var url = 'https://maps.google.com/maps/api/directions/json?language=en&origin='+origin+'&destination='+destination+'&sensor=false&key='+this.directionsApiKey;
var result = Meteor.http.get(url);
if(result.statusCode == '200' && result.content){
var content = JSON.parse(result.content);
if(content && content.routes && content.routes[0] && content.routes[0].legs && content.routes[0].legs[0]){
var tmp = content.routes[0].legs[0];
if(tmp.distance && tmp.distance.value){
distance = tmp.distance.value;
}
if(tmp.duration && tmp.duration.value){
duration = tmp.duration.value;
}
}
}
私のhttpリクエストがタイムアウトしたようです..コードをtry catchにも入れましたが、catch部分にはなりません。ここで何が問題になる可能性がありますか?