Apache ProxyPass to Rack da error 404

Apache ProxyPass to Rack da error 404

(para simplificar, cambié las IP del servidor Apache a 1.1.1.1 y el servidor Gollum a 6.6.6.6)

Estoy tratando de servir unGollumwiki con rack a través de Apache (ya que tiene SSL configurado correctamente y actualmente solo estoy probando el wiki de Gollum). Entonces configuré Apache para ProxyPass (configuración a continuación).

El problema es que el servidor en rack parece funcionar bien cuando accedo directamente a través de un curl desde mi máquina proxy:

1.1.1.1 - - [05/Dec/2013 06:20:25] "GET /docs/Home HTTP/1.1" 200 6467 0.2135

pero recibo un 404 cada vez que intento usar mi navegador. Rackup dice:

6.6.6.6 - - [05/Dec/2013 06:20:00] "GET /docs/Home HTTP/1.1" 404 - 0.0006

Absurdamente, cuando uso elexactoLos mismos encabezados que envía mi navegador (ver más abajo) a través de telnet desde la máquina proxy (1.1.1.1) la solicitud se realizó correctamente:

6.6.6.6 - - [05/Dec/2013 06:19:19] "GET /docs/Home HTTP/1.1" 200 6467 0.2759

No tengo idea de qué estoy haciendo mal y por qué (¡¿y cómo?!) rack diferencia entre dos solicitudes diferentes de la misma máquina. ¿Ayuda por favor?

(Usando Apache/2.2.15 en RHEL 5 y Rack 1.2 (Versión: 1.5) en Ruby 1.9.2p320, RHEL 6)

EDITARAl parecer esto es un problema con WEBrick, ya que cuando cambio a Thin funcionó. Todavía me gustaría conocer sus ideas...


Configuración de Apache:

<VirtualHost 1.1.1.1:80>

    ServerName testserver.example.org
    ServerAlias testserver.example.org
    ServerAdmin [email protected]

    DocumentRoot /path/to/my/docs
    DirectoryIndex index.html index.htm index.php

    # ...

    <Location /docs/>
        ProxyPass http://6.6.6.6:8080/docs/

        # also tried:
        # ProxyPass http://rackserver.example.org:8080/docs/

        # and:
        # SetEnv force-proxy-request-1.0 1
        # SetEnv proxy-nokeepalive 1

    </Location>

</VirtualHost>

Solicitud por Telnet:

<1>root@testserver:~$ telnet rackserver.example.org 8080
Trying 6.6.6.6...
Connected to rackserver.example.org.
Escape character is '^]'.
GET /docs/Home HTTP/1.1
ACCEPT: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
ACCEPT_ENCODING: gzip,deflate,sdch
ACCEPT_LANGUAGE: en-US,en;q=0.8,he;q=0.6
CACHE_CONTROL: max-age=0
COOKIE: SESS...; has_js=1
HOST: rackserver.example.org:8080
USER_AGENT: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.57 Safari/537.36
VERSION: HTTP/1.1
X_FORWARDED_FOR: 6.6.6.6
X_FORWARDED_HOST: apacheserver.example.org
X_FORWARDED_SERVER: testserver.example.org

Verifiqué que el rack up imprime el mismo resultado para la solicitud normal del navegador y la solicitud por telnet usandoel código de esta respuesta.

información relacionada