http.request可以连接到多个主机(node.js)吗?

时间:2012-08-01 22:25:15

标签: node.js httpwebrequest

最初http.request只能连接到一台主机。是否有其他方法或其他方法可以指定多个主机来创建http远程请求客户端?

背后的原因是我正在连接的远程服务有三个冗余主机,如果一个停机,其他主机将继续工作。所以,我正在寻找一种方法来使http.request或任何请求客户端指定多个主机,并连接到正在工作的主机。如果第一个主机出现故障,请切换到列表中的另一台主机。

2 个答案:

答案 0 :(得分:1)

听起来你想在三台主机之间进行负载均衡。那是对的吗?如果是这样,那么this post可能有所帮助。基本上,我们的想法是,您将发送到特定主机(虚拟)的负载均衡器,然后它将代理(循环)到真实服务器(真实)。要获得完全冗余,您需要查找可以群集的负载均衡器。

编辑: 我已经使用HAProxy进行负载平衡,并发现它运行良好。它允许您配置绑定到IP的虚拟主机。然后,从该虚拟IP转发到 n 数量的真实服务器。

答案 1 :(得分:0)

你可以再做一个,直到有效:

var hosts = ["first.com", "second.com", "third.com"];
(function loop(i) {
    var host = hosts[i],
        options = {
            host: host,
            port: 80,
            method: 'GET'
        };
    if (host) {
        var req = http.request(options, function(res) {
            if (res.statusCode !== 200) {
                loop(++i)
            } else {
                console.log("request succeeded");
            }
        });
        req.on("error", function() {
            loop(++i);
        });
        req.end();
    } else {
        console.log("ran out of hosts to try");
    }
})(0);