Ich habe 2 Springboot-Anwendungen, die auf den Ports 9000 und 9001 laufen. Ich habe HaProxy auch mit einem Docker-Container ausgeführt. Meine Konfigurationsdatei sieht wie folgt aus:
global
defaults
mode http
timeout connect 5000ms
timeout client 5000ms
timeout server 5000ms
frontend http-in
bind *:80
acl has_web1 path_beg /web1
acl has_web2 path_beg /web2
use_backend web1 if has_web1
use_backend web2 if has_web2
default_backend web1
backend web1
server web1 127.0.0.1:9000 check
backend web2
server web2 127.0.0.1:9001 check
Wenn ich versuche, auf eine URL zuzugreifen, beispielsweise localhost/web1, wird der Fehlercode 503 angezeigt.
Kann mir jemand sagen, warum das so ist? Die Docker-Compose-Datei lautet:
version: '3'
services:
#web1:
# image: dockercloud/hello-world
# container_name: web1
# ports:
# - "81:80"
#web2:
# image: dockercloud/hello-world
# container_name: web2
# ports:
# - "82:80"
haproxy:
build: ./haproxy
container_name: haproxy
ports:
- "80:80"
Und das Dockerfile ist:
FROM haproxy:1.7
COPY haproxy.cfg /usr/local/etc/haproxy/haproxy.cfg
Ich arbeite unter Windows, falls das wichtig ist.
Edit: Ich bin auf die Version 2.1.2 von HaProxy umgestiegen und habe folgende Warnung erhalten
gs:
haproxy | [NOTICE] 020/002817 (1) : New worker #1 (6) forked
haproxy | [WARNING] 020/002817 (6) : Server web1/web1 is DOWN, reason: Layer4 connection problem, info: "Connection refused", check duration: 0ms. 0 active and 0 backup servers left. 0 sessions active, 0 requeued, 0 remaining in queue.
haproxy | [ALERT] 020/002817 (6) : backend 'web1' has no server available!
haproxy | [WARNING] 020/002818 (6) : Server web2/web2 is DOWN, reason: Layer4 connection problem, info: "Connection refused", check duration: 0ms. 0 active and 0 backup servers left. 0 sessions active, 0 requeued, 0 remaining in queue.
haproxy | [ALERT] 020/002818 (6) : backend 'web2' has no server available!
Liegt das am Docker-Container??