Как вы маскируете URL-адреса в HAProxy?
Есть ли способ сделать маскировку URL в HAProxy? Мне бы хотелось, чтобы URL направлял мой балансировщик нагрузки, например, http://www.example.com/, перенаправлял на другой URL, который я имею для другого приложения. Однако я бы хотел, чтобы в браузере пользователя отображался оригинальный URL-адрес ( http://www.example.com/). Как бы я пошел по этому поводу?
2 ответа
Вместо того, чтобы маскировать URL-адреса, мы поняли, что можем сделать это проще, просто перенаправив бэкэнд при отправке на бэкэнд-сервер. Я не знаю, является ли это идеальным, но пока мы достигли нашей цели. Вот код:
внешний интерфейс http_in
...
acl is_test1.domain.com hdr(host) -i test1.domain.com # Host & Domain only check.
acl is_path_null path / # No path check
use_backend domain.com.nopath if is_test1.domain.com is_path_null # If Host & Domain matches and path is null.
use_backend domain.com.path if is_test1.domain.com !is_path_null # If Host & Domain matches and path is not null.
внешний интерфейс https_in
...
acl is_path_null path / # No path check
use_backend domain.com.nopath if { ssl_fc_sni -i test1.domain.com } is_path_null # If Host & Domain matches and path is null.
use_backend domain.com.path if { ssl_fc_sni -i test1.domain.com } !is_path_null # If Host & Domain matches and path is not null.
backend domain.com.nopath
...
server SERVER IP#:80 redir https://test1.domain.com/webapp check
backend domain.com.path
...
server SERVER IP#:80 check
Вы можете сделать это, используя reqrep
,
frontend FE
bind 10.10.10.10:80
mode http
acl is_domain.com hdr(host) -i domain.com
use_backend BE:domain.com if is_domain.com
backend BE:domain.com
mode http
reqrep ^([^\ ]*)\ (.*) \1\ /path/\2
server domain2.com:80
Хотя вы, вероятно, должны поставить IP, который domain2.com
решает в server
линия, чтобы вы не в конечном итоге странного поведения.