Docker Swarm HAProxy无负载均衡与覆盖网络

时间:2015-12-24 21:26:13

标签: docker haproxy docker-compose docker-swarm

过去几天我一直在努力在Digtital Ocean上创建一个码头群。注意:我不想使用-link与其他应用程序/容器进行通信,因为它们在技术上被认为已被弃用,并且与docker swarm不兼容(即我无法向负载添加更多应用程序实例)平衡器没有重新组成整个群体)

我根据this guide使用一台服务器作为运行控制台的kv-store服务器。 Becasue我在数字海洋,我在DO上使用私人网络,所以机器可以相互通信。

然后我创建一个配置单元主服务器和从服务器,并启动在所有计算机上运行的覆盖网络。这是我的docker-compose.yml

proxy:
    image: tutum/haproxy 
    ports:
        - "1936:1936"
        - "80:80"

web:
    image: tutum/hello-world
    expose:
        - "80"

因此,当我这样做时,它会创建2个容器。 HAProxy正在运行,因为我可以在http://<ip-address>:1936处访问端口1936处的统计信息,但是,当我尝试在端口80处转到Web服务器/负载均衡器时,我的连接被拒绝。当我运行docker-compose ps

时,我似乎似乎已经连接了
       Name                      Command               State                                 Ports
--------------------------------------------------------------------------------------------------------------------------------
splashcloud_proxy_1   python /haproxy/main.py          Up      104.236.109.58:1936->1936/tcp, 443/tcp, 104.236.109.58:80->80/tcp
splashcloud_web_1     /bin/sh -c php-fpm -d vari ...   Up      80/tcp

我唯一能想到的是它没有链接到Web容器,但我不确定如何解决这个问题。

我很感激你的帮助。

2 个答案:

答案 0 :(得分:7)

不幸的是,你不能在这里使用tutum haproxy版本。此图像专门针对链接进行了定制。 你需要一些脚本化的方式将web服务器ip传递给haproxy我担心。

但这并不是那么难:)我建议你从这个例子开始: 首先设置docker-compose.yml =&gt;让我们使用两个节点,这样你就可以确保你所做的事情是有意义的,并且实际上是负载平衡:)

proxy:
    build: ./haproxy/
    ports:
        - "1936:1936"
        - "80:80"
web1:
    container_name: web1
    image: tutum/hello-world
    expose:
        - "80"
web2:
    container_name: web2
    image: tutum/hello-world
    expose:
        - "80"

现在使用haproxy,您需要根据官方图像文档设置自己的Dockerfile: https://hub.docker.com/_/haproxy/

我使用建议的文件在haproxy子文件夹中执行了此操作:

FROM haproxy
COPY haproxy.cfg /usr/local/etc/haproxy/haproxy.cfg

然后对于haproxy配置文件haproxy.cfg我测试了这个:

global
    stats socket /var/run/haproxy.stat mode 660 level admin
    stats timeout 30s
    user root
    group root

defaults
    mode    http
    timeout connect 5000
    timeout client  50000
    timeout server  50000

frontend localnodes
    bind *:80
    mode http
    default_backend nodes

backend nodes
    mode http
    balance roundrobin
    option forwardfor
    http-request set-header X-Forwarded-Port %[dst_port]
    http-request add-header X-Forwarded-Proto https if { ssl_fc }
    option httpchk HEAD / HTTP/1.1\r\nHost:localhost
    server web01 172.17.0.2:80
    server web02 172.17.0.3:80

listen stats 
    bind *:1936
    mode http
    stats enable
    stats uri /
    stats hide-version
    stats auth someuser:password

显然这里的IP只能在默认设置中工作我完全清楚这一点:) 你需要对这两行做点什么:

server web01 172.17.0.2:80
server web02 172.17.0.3:80

我认为你在这里与Digital Ocean合作很幸运:)据我所知,你确实拥有私人IP地址,你可以使用DO来计划运行swarm节点。我建议简单地把那些节点IP而不是我的示例IP并在它们上运行你的web服务器并且你很好:)

答案 1 :(得分:0)

添加指向docker-compose.yml的链接

proxy:
    image: tutum/haproxy 
    ports:
        - "1936:1936"
        - "80:80"
    links:
        - web
web:
    image: tutum/hello-world
    expose:
        - "80"