В своем приложении я создаю стандартный сценарий, в котором веб-приложение Java развертывается на JBoss с предварительным прокси-сервером apache. Веб-приложение доступно из контекста / esp, поэтому прямой URL-адрес будет (но я отключил HTTP для Jboss, только AJP):
http://1.2.3.4:8080/esp
Теперь я создал поддомен и попробовал прокси-сервер перемещаться через корневой контекст apache. Итак, я бы хотел, чтобы apache прокси:
https://mysubdomain.domain.com -> ajp -> Jboss /esp context app
Я считаю, что мне не хватает чего-то очевидного в моей конфигурации, потому что доступен только контекст корневого приложения, а остальная часть URL-адреса имеет двойной контекст, который заканчивается на 404. Например, запрос проксируется следующим образом:
https://mysubdomain.domain.com/css/somecss.css -> ajp -> /esp/esp/css/somecss.css
Конфигурация Apache выглядит так:
<VirtualHost 1.2.3.4:80>
ServerName mysubdomain.domain.com
RewriteEngine on
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^/(.*) https://%{HTTP_HOST}/$1 [NC,R=301,L]
</VirtualHost>
<IfModule mod_ssl.c>
<VirtualHost 1.2.3.4:443>
ServerName mysubdomain.domain.com
ProxyPass / ajp://localhost:8009/esp/
ProxyPassReverse / ajp://localhost:8009/esp/
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
<Directory /var/www/mantis>
Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
allow from all
</Directory>
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
LogLevel warn
CustomLog ${APACHE_LOG_DIR}/esp.log combined
Alias /doc/ "/usr/share/doc/"
<Directory "/usr/share/doc/">
Options Indexes MultiViews FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
Allow from 127.0.0.0/255.0.0.0 ::1/128
</Directory>
SSLEngine on
SSLCertificateFile /var/keys/server.crt
SSLCertificateKeyFile /var/keys/server.key
<FilesMatch "\.(cgi|shtml|phtml|php)$">
SSLOptions +StdEnvVars
</FilesMatch>
<Directory /usr/lib/cgi-bin>
SSLOptions +StdEnvVars
</Directory>
BrowserMatch "MSIE [2-6]" \
nokeepalive ssl-unclean-shutdown \
downgrade-1.0 force-response-1.0
BrowserMatch "MSIE [17-9]" ssl-unclean-shutdown
</VirtualHost>
</IfModule>
Более того, когда я добавляю дополнительные прокси заранее, все работает:
ProxyPass /esp/ ajp://localhost:8009/esp/
ProxyPassReverse /esp/ ajp://localhost:8009/esp/
За исключением того, что приложение доступно из apache в обоих контекстах: /
и /esp
пока хочу только рут. Как я могу это исправить?
У меня уже была похожая проблема, похожая на ту, что у вас здесь, и я, наконец, нашел свою соответствующую конфигурацию (адаптированную к конфигурации, которую вы опубликовали):
ProxyRequests Off
ProxyPass / ajp://localhost:8009/esp/
ProxyPassReverse / http://mysubdomain.domain.com/esp/
ProxyPassReverse / https://mysubdomain.domain.com/esp/
ProxyPassReverseCookiePath "/esp" "/"
Изначально у меня были проблемы с ProxyPassRevers, но также и с путём cookie, даже, возможно, вам может понадобиться ProxyPassReverseCookieDomain
Директива (в моем случае она мне не понадобилась).