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

настройка базового виртуального хоста mod_proxy

Я пытаюсь настроить базовый виртуальный хост для проксирования всех запросов на test.local на сервер WEBrick, который у меня работает на 127.0.0.1:8080, сохраняя при этом все запросы на localhost, идущие к моим статическим файлам в / var / www. Я использую Ubuntu 10.04.

У меня установлен libapache2-mod-proxy-html, и у меня включен модуль с прокси a2enmod. У меня также включен мой виртуальный хост. Однако всякий раз, когда я перехожу на test.local, я всегда получаю загадочную ошибку сервера 500, и все мои журналы говорят мне:

[Thu Mar 03 01:43:10 2011] [warn] proxy: No protocol handler was valid for the URL /. If you are using a DSO version of mod_proxy, make sure the proxy submodules are included in the configuration using LoadModule.

Вот мой виртуальный хост:

<VirtualHost test.local:80>
    LoadModule proxy_module /usr/lib/apache2/modules/mod_proxy.so
    ServerAdmin webmaster@localhost
    ServerName test.local
    ProxyPreserveHost On

    # prevents this folder from being proxied
    ProxyPass /static !

    DocumentRoot /var/www
    <Directory />
        Options FollowSymLinks
        AllowOverride None
    </Directory>
    <Directory /var/www/>
        Options Indexes FollowSymLinks MultiViews
        AllowOverride None
        Order allow,deny
        allow from all
    </Directory>

    <Proxy *>
        Order allow,deny
        Allow from all
    </Proxy>
    ProxyPass / http://localhost:8080/
    ProxyPassReverse / http://localhost:8080/

    ErrorLog /var/log/apache2/error.log

    # Possible values include: debug, info, notice, warn, error, crit,
    # alert, emerg.
    LogLevel warn

    CustomLog /var/log/apache2/access.log combined

а вот мои настройки для mod_proxy:

<IfModule mod_proxy.c>
        #turning ProxyRequests on and allowing proxying from all may allow
        #spammers to use your proxy to send email.

        ProxyRequests Off

        <Proxy *>
        # default settings
                #AddDefaultCharset off
                #Order deny,allow
                #Deny from all
                ##Allow from .example.com

        AddDefaultCharset off
        Order allow,deny
        Allow from all
        </Proxy>

        # Enable/disable the handling of HTTP/1.1 "Via:" headers.
        # ("Full" adds the server version; "Block" removes all outgoing Via: headers)
        # Set to one of: Off | On | Full | Block

        ProxyVia On
</IfModule>

Кто-нибудь знает, что я делаю не так? Спасибо

Похоже, вы не загружаете mod_proxy_http модуль (который необходим для проксирования HTTP-серверов). Передо мной нет Ubuntu 10.04, но IIRC это что-то вроде:

sudo a2enmod proxy_http

Приведенный выше ответ мне не помог, так как я получал ту же ошибку, что и в комментарии автора в выбранном ответе. Однако я нашел следующее сообщение и изменение, которое решило мою проблему:

sudo /usr/sbin/setsebool -P httpd_can_network_connect 1

Источник: http://allscm.com/archives/apache2-proxy-disabled-connection-on-localhost.html