
(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.