【发布时间】:2015-02-26 04:13:29
【问题描述】:
我正在使用来自https://github.com/dockerfile/haproxy 的默认 HAProxy Docker 映像
不幸的是,我无法让它正确地重新加载我的配置。
如果我跑了
$ sudo docker exec haprox haproxy -f /etc/haproxy/haproxy.cfg -p '$(</var/run/haproxy.pid)' -st '$(</var/run/haproxy.pid)'
它只是转储帮助文件。如果我跑
$ sudo docker exec haprox 'haproxy -f /etc/haproxy/haproxy.cfg -p $(</var/run/haproxy.pid) -st $(</var/run/haproxy.pid)'
我明白了
2014/12/30 00:03:23 docker-exec: failed to exec: exec: "haproxy -f /etc/haproxy/haproxy.cfg -p $(</var/run/haproxy.pid) -st $(</var/run/haproxy.pid)": stat haproxy -f /etc/haproxy/haproxy.cfg -p $(</var/run/haproxy.pid) -st $(</var/run/haproxy.pid): no such file or directory
嘘。这些都不是我想要的。我可以运行docker exec haprox service haproxy reload - 但这最终会产生几个haproxy进程,所以当我通过unix套接字连接时,我从show stat得到一组信息,但我得到一组完全不同的信息从 http 统计页面。
我正在尝试对其进行设置,以便我可以优雅地重新部署我们的旧软件,但它对 Tomcat 会话做了非常非常坏事,所以我唯一的选择是保留现有会话活着并 ping 同一个服务器。
backend legacy
cookie SERVERID insert indirect preserve
server A 123.0.0.123:8080 cookie A check
server B 123.0.0.123:8080 cookie B check
成功了。我可以调用套接字并运行set weight legacy/A 0,它将耗尽来自服务器 A 的连接。
但是(还记得那个遗留的部分吗?)我必须将我的服务器 A/B 容器放在头上并调出新的容器。我已经完成了系统设置,可以很好地生成新配置,但是当我重新加载时……奇怪的事情发生了。
如前所述,它最终会产生几个 haproxy 进程。我从 stats page 和 unix socket 得到不同的信息。我在浏览器和socat中通信的进程的pid文件似乎也不同。
不过,最糟糕的是,它会以 503 停止 http 连接 - 并且使用 ab 进行测试会报告一些断开的连接。这部分不行。
旧会话必须继续运行,直到旧服务器关闭/cookie 被清除。似乎互联网的其余部分能够做我想做的事情......我在这里做错了什么?
【问题讨论】:
-
FYI 官方 HAProxy 图像在这里 registry.hub.docker.com/_/haproxy 不是你链接的那个
-
其实现在就在这里:github.com/docker-library/haproxy