Zac*_*ell 9 haproxy docker docker-compose docker-swarm
过去几天我一直在努力在Digtital Ocean上创建一个码头群.注意:我不想使用-link与其他应用程序/容器进行通信,因为它们在技术上被认为已被弃用,并且与docker swarm不兼容(即我无法在不重新编写的情况下向负载均衡器添加更多应用程序实例整个群体)
我根据本指南使用一台服务器作为运行控制台的kv-store服务器.Becasue我在数字海洋,我在DO上使用私人网络,所以机器可以相互通信.
然后我创建一个配置单元主服务器和从服务器,并启动在所有计算机上运行的覆盖网络.这是我的docker-compose.yml
proxy:
image: tutum/haproxy
ports:
- "1936:1936"
- "80:80"
web:
image: tutum/hello-world
expose:
- "80"
Run Code Online (Sandbox Code Playgroud)
因此,当我这样做时,它会创建2个容器.HAProxy正在运行,因为我可以访问端口1936处的统计信息http://<ip-address>: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
Run Code Online (Sandbox Code Playgroud)
我唯一能想到的是它没有链接到Web容器,但我不确定如何解决这个问题.
我很感激你的帮助.
你不能在这里使用tutum haproxy版本.此图像专门针对链接进行了定制.你确实需要一些脚本化的方式将web服务器ip传递给haproxy我担心.
但这并不是那么难:)我建议你从这个例子开始:首先设置docker-compose.yml =>让我们使用两个节点,这样你就可以确保你所做的事情有意义并实际加载一路平衡:)
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"
Run Code Online (Sandbox Code Playgroud)
现在使用haproxy,你需要根据官方图像文档设置自己的Dockerfile:https://hub.docker.com/_/haproxy/
我在haproxy子文件夹中使用建议的文件执行此操作:
FROM haproxy
COPY haproxy.cfg /usr/local/etc/haproxy/haproxy.cfg
Run Code Online (Sandbox Code Playgroud)
那么对于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
Run Code Online (Sandbox Code Playgroud)
显然这里的IP只能在默认设置中工作我完全清楚这一点:)你需要对这两行做些什么:
server web01 172.17.0.2:80
server web02 172.17.0.3:80
Run Code Online (Sandbox Code Playgroud)
我认为你在这里与Digital Ocean合作很幸运:)据我所知,你确实拥有私人IP地址,你可以使用DO来计划运行swarm节点.我建议简单地把那些节点IP而不是我的示例IP并在它们上运行你的web服务器,你很好:)
| 归档时间: |
|
| 查看次数: |
1949 次 |
| 最近记录: |