Je dois équilibrer la charge entre plusieurs serveurs en cours d'exécution avec des noms d'hôtes différents. Je ne peux pas configurer le même hôte virtuel sur chacun d'eux.
Est-il possible d'avoir une seule configuration d'écoute avec plusieurs serveurs et de faire appliquer la http-send-name-header Host
directive aux contrôles d' intégrité? J'utilise HAProxy 1.5.
J'ai trouvé ce haproxy.cfg fonctionnel, comme vous pouvez le voir, j'ai dû définir un nom d'hôte différent pour chaque contrôle de santé car le contrôle de santé ignore le http-send-name-header Host
. J'aurais préféré utiliser des variables ou d'autres méthodes et garder les choses plus concises.
global
log 127.0.0.1 local0 notice
maxconn 2000
user haproxy
group haproxy
defaults
log global
mode http
option httplog
option dontlognull
retries 3
option redispatch
timeout connect 5000
timeout client 10000
timeout server 10000
stats enable
stats uri /haproxy?stats
stats refresh 5s
balance roundrobin
option httpclose
listen inbound :80
option httpchk HEAD / HTTP/1.1\r\n
server instance1 127.0.0.101 check inter 3000 fall 1 rise 1
server instance2 127.0.0.102 check inter 3000 fall 1 rise 1
listen instance1 127.0.0.101:80
option forwardfor
http-send-name-header Host
option httpchk HEAD / HTTP/1.1\r\nHost:\ www.example.com
server www.example.com www.example.com:80 check inter 5000 fall 3 rise 2
listen instance2 127.0.0.102:80
option forwardfor
http-send-name-header Host
option httpchk HEAD / HTTP/1.1\r\nHost:\ www.bing.com
server www.bing.com www.bing.com:80 check inter 5000 fall 3 rise 2
example.heroku.com