У меня был некоторый первоначальный успех в настройке HAProxy нескольких серверов приложений, прослушивающих различные другие порты.
Теперь у меня есть другой веб-сервер, прослушивающий один порт, и я хотел бы, какие изменения внести в мою конфигурацию, чтобы поток трафика также передавался по имени хоста.
Ниже приводится текущая настройка, предполагающая:
global log 127.0.0.1 local0 log 127.0.0.1 local1 notice maxconn 4096 debug #quiet #user haproxy #group haproxy defaults log global mode http option httplog option dontlognull retries 3 redispatch maxconn 2000 contimeout 5000 clitimeout 50000 srvtimeout 50000 listen appservers 0.0.0.0:80 mode http balance roundrobin option httpclose option forwardfor #option httpchk HEAD /check.txt HTTP/1.0 server inst1 0.0.0.0:8081 cookie server01 check inter 2000 fall 3 server inst2 0.0.0.0:8082 cookie server02 check inter 2000 fall 3 server inst3 0.0.0.0:8083 cookie server01 check inter 2000 fall 3 server inst4 0.0.0.0:8084 cookie server02 check inter 2000 fall 3 capture cookie vgnvisitor= len 32
(любые другие комментарии по настройке ^ приветствуются.)
Теперь я хотел бы продолжить то же самое, но в дополнение к этому - если имя хоста - myspecialtopleveldomain <dot> com, тогда я хотел бы передавать трафик на example <dot> com: 8001
~ B
Вот пример:
frontend http
bind 0.0.0.0:80
default_backend www
# NAT static host names and static paths in other hostnames to a different backend
acl host_static hdr_beg(host) -i static.
acl url_static path_beg /static
use_backend static if host_static or url_static
backend www
balance roundrobin
server qa1 10.177.1.81:80
server qa2 10.177.1.45:80
backend static
balance roundrobin
server media1 10.177.0.86:80