Есть ли способ сделать маскировку URL в HAProxy? Я хотел бы иметь URL-адрес, указывающий на мой балансировщик нагрузки, т.е. www.example.com, перенаправить на другой URL, который у меня есть для другого приложения. Однако я бы хотел, чтобы браузер пользователя по-прежнему отображал исходный URL-адрес (www.example.com). Как мне это сделать?
Мы поняли, что вместо того, чтобы выполнять маскировку 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
линия, чтобы вы не закончили странным поведением.