Мне удалось добиться некоторого первоначального успеха с помощью HAProxy, настроив несколько серверов приложений, прослушивающих различные другие порты.
Теперь у меня есть еще один веб-сервер, прослушивающий один порт, и я хотел бы узнать, какие изменения нужно внести в мою конфигурацию, чтобы трафик также передавался по имени хоста.
Ниже приведена текущая настройка, предполагающая:
- мой веб-сервер Apache работает по адресу examplecom:8001
- моя группа серверов приложений 0.0.0.0:8081, 0.0.0.0:8082 , 0.0.0.0:8083
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
~Б
решение1
Вот пример:
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