Node.JS HTTP请求超时

时间:2013-09-05 23:54:05

标签: node.js

我有一个应用程序需要对主URL和辅助URL的HTTP请求。当主URL关闭时,我需要能够正常处理这个并故障转移到辅助URL。我已经运行了故障转移功能,但遇到了处理超时的问题。

经过一番搜索,我发现Node没有默认超时,所以我设置了一个。我遇到的问题是在设置请求超时后套接字保持打开状态。如果我销毁或中止请求,它会抛出一个很快就退出的错误。我知道我可以使用req.on('error')处理这个问题,但我希望能够在必要时将其用于其他错误处理。我尝试了几种方法来运行时间。

第一种是在套接字上设置超时并将其销毁。这会导致套接字挂起错误。

var req= https.request(options, function(res){
    //Handle response based on return code
});


req.on('socket', function(socket){
     socket.setTimeout(10000);
     socket.on('timeout', function(){
         socket.destroy();
          self.emit("runAgain");
     })
});

req.on('error', function(err){
    console.log(err);
}); 

req.end();

我尝试的另一种方法是在请求上设置超时。这导致ECONNRESET错误。

req.setTimeout(100, function(){
   req.destroy();
   console.log('request destroyed');
})

我正在寻找处理此问题的最佳方法,以便我不必设置超时,然后在可能的情况下捕获错误。

1 个答案:

答案 0 :(得分:0)

您可以订阅自己正在发行的“runAgain”事件,也可以保留一个计数器或者其他内容:

self.madeSecondaryRequest = false;

self.on("runAgain", function() {
    if(!self.madeSecondaryRequest) {
        console.log("Hey I could make my request again!");
        self.madeSecondaryRequest = true;
    }
});