我在Amazon EC2负载均衡器后面有几个Web服务器。我在端口80上使用TCP平衡(而不是HTTP平衡)。
我有一个客户端每隔几秒钟轮询一个Web服务(在所有Web服务器上运行)以获取新项目。但是,客户端似乎保持与一台服务器的连接,并且每次轮询同一台服务器。
我尝试使用ServicePointManager来禁用KeepAlive,但这并没有改变任何东西。传出连接仍然具有“connection:keep-alive”HTTP标头,并且服务器保持TCP连接打开。我也尝试将GetWebRequest的重写添加到VS创建的代理类中,该代理类继承自SoapHttpClientProtocol,但我仍然看到了keep-alive标头。
如果我终止客户端进程并重新启动,它将通过负载均衡器连接到新服务器,但它将继续永久轮询该新服务器。
有没有办法强制它每次都连接到随机服务器?我希望来自一个客户端的负载分布在所有Web服务器上。
客户端是用C#编写的(与服务器一样)并使用Web引用(不是服务引用),它指向负载均衡器。
答案 0 :(得分:9)
不会覆盖GetWebRequest方法:
protected override WebRequest GetWebRequest(Uri uri)
{
var webRequest = (HttpWebRequest)base.GetWebRequest(uri);
webRequest.KeepAlive = false;
return webRequest;
}