Назад | Перейти на главную страницу

Директивы apache 2.4 ProxyPass не работают в RHEL7.5

У меня проблемы с настройкой обратного прокси с apache 2.4.6 на RHEL7.5.

У меня есть следующий виртуальный хост, который отправляет запросы на 3 бэкэнда:

<VirtualHost *:80>
    ServerName www.example.com

    RewriteEngine On

    ProxyPreserveHost On

    <Proxy balancer://backend8093>
        BalancerMember http://backend01:8093 route=1
        BalancerMember http://backend02:8093 route=2
        BalancerMember http://backend03:8093 route=3
        ProxySet lbmethod=bybusyness
        Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
        ProxySet stickysession=ROUTEID
    </Proxy>

    # v1, works
    #RewriteRule ^/scheduler/(.*) proxy:balancer://backend8093/scheduler/$1 [L]

    # v2, doesn't work
    ProxyPass "/scheduler" "balancer://backend8093/scheduler"
    ProxyPassReverse "/scheduler" "balancer://backend8093/scheduler"

    RewriteRule .* http://failure [R,L]

</VirtualHost>

Однако когда я пробую завить локон, я придерживаюсь последнего правила:

# curl -vvv -H "host: www.example.com" localhost/scheduler/xxx
* About to connect() to localhost port 80 (#0)
*   Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 80 (#0)
> GET /scheduler/xxx HTTP/1.1
> User-Agent: curl/7.29.0
> Accept: */*
> host: www.example.com
>
< HTTP/1.1 302 Found
< Date: Thu, 07 Jun 2018 16:04:46 GMT
< Server: Apache/2.4.6 (Red Hat Enterprise Linux) OpenSSL/1.0.2k-fips
< Location: http://failure
< Content-Length: 198
< Content-Type: text/html; charset=iso-8859-1

что означает, что ProxyPass директива не соответствует моему запросу. Я также пробовал обернуть ProxyPass* директивы в <Location> директива, но она тоже не сработала.

Пробуем эквивалентное правило (v1) с RewriteRule работает, как ожидалось, балансируя запросы между 3 серверами:

# curl -vvv -H "host: www.example.com" localhost/scheduler/xxx
* About to connect() to localhost port 80 (#0)
*   Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 80 (#0)
> GET /scheduler/xxx HTTP/1.1
> User-Agent: curl/7.29.0
> Accept: */*
> host: www.example.com
>
< HTTP/1.1 200 OK
< Date: Thu, 07 Jun 2018 16:06:34 GMT
< Server: Apache/2.4.6 (Red Hat Enterprise Linux) OpenSSL/1.0.2k-fips
< Last-Modified: Thu, 07 Jun 2018 13:20:51 GMT
< ETag: "11-56e0d26f87639"
< Accept-Ranges: bytes
< Content-Length: 17
< Set-Cookie: ROUTEID=.1; path=/
<
backend01 hello

Я вижу, что запросы соответствуют правильному VirtualHost, так как я вижу перенаправления, но не могу понять, почему ProxyPass похоже, игнорируется.

Я проверил, и apache загружает модули (подтверждено также server-info обработчик):

# httpd -M | grep proxy
proxy_module (shared)
proxy_ajp_module (shared)
proxy_balancer_module (shared)
proxy_connect_module (shared)
proxy_express_module (shared)
proxy_fcgi_module (shared)
proxy_fdpass_module (shared)
proxy_ftp_module (shared)
proxy_http_module (shared)
proxy_scgi_module (shared)
proxy_wstunnel_module (shared)

У меня есть другие серверы с аналогичными настройками, на которых работают apache v2.4.6 на RHEL7.4 и apache 2.2.15 на RHEL6.5. Я не могу найти никакой разницы в загруженных модулях между серверами RHEL7, но по-прежнему один работает, а другой нет.

Вероятно, есть какая-то разница в конфигурации, которой мне не хватает. Конфигурация в основном стандартная, с изменениями только файлов в /etc/httpd/conf.d (указанный выше виртуальный хост содержится в собственном файле).

Что здесь не так? Почему не ProxyPass директивная работа?

RewriteRule обрабатывается во время выполнения до ProxyPass. Общее правило RewriteRule будет соответствовать всему. Удалите это правило и используйте вместо него директивы ErrorPage.