由于持久连接,HAProxy 没有负载均衡

HAProxy is not load balancing due to persistent connections

我们有一个 web 服务器和一个客户端,都是用 go 编写的,它们相互交互。我们希望 HAProxy 在服务器的多个实例之间负载平衡请求,但它不起作用。客户端将始终连接到同一台服务器,而它仍然处于运行状态。

如果我查看 "netstat -anp" 的输出,我可以看到客户端和服务器之间通过 HAProxy 建立了持久连接。我尝试在对 "close" 的响应中设置连接 Header,但这根本不起作用。

不用说,我对此完全感到困惑。我的第一个问题是,这是客户端、服务器或 HAProxy 的问题吗?如何强制客户端断开连接?我错过了什么吗? Curl 工作正常,所以我知道 HAProxy 会进行负载平衡,但 curl 在完成后也会完全关闭,因此我怀疑是持久连接导致了我的问题,因为客户端和服务器很长 运行。

仅供参考,我在服务器上使用 go-martini。

谢谢。

HTTP/1.1 默认使用 KeepAlive。由于连接未关闭,HAProxy 无法平衡不同后端之间的请求。

您有几个选择:

在您的代码中每次请求后强制关闭连接。在客户端或服务器上设置 Request.Close = true 将发送 Connection: close header,告诉双方关闭 tcp 连接。

或者,您可以通过设置 http-server-close 让 HAPoxy 更改请求,以便在每次请求后关闭后端,或者 http-close 在每次请求后关闭双方。

http-server-close 通常是最佳选择,因为它仍然为客户端保持持久连接,同时单独代理每个请求。