У меня такая настройка:
Интернет - маршрутизатор - [DMZ] - pfsense - веб-сервер
router =
jenky пластиковый дешево-o роутер (умер мой симпатичный микротик / роутерборд). Установлен IP-адрес pfsense в DMZ.
pfsense =
выполнение базового брандмауэра плюс прокси / обратный прокси. Прокси-серверы предназначены для перенаправления URL-адресов на правильный веб-сервер за брандмауэром.
webserver =
В модуле centos работают httpd (apache) и tomcat6 (устанавливаются отдельно, оба из yum, но в разное время, так что это не apache + tomcat).
Несколько веб-сайтов запускаются с этого конкретного веб-сервера, обрабатываемого виртуальными хостами apache.
ex: http://www.example.com, http://www.example1.com, etc
Tomcat запускает приложение на порту 8080 в расширении / mywebapp.
ex: http://www.example.com:8080/mywebapp
Я правильно все настроил в pfsense
перенаправить все поддомены веб-сайтов, обслуживаемых apache, на правильный хост.
Я настроил /etc/httpd/conf/httpd.conf, чтобы включить конфигурацию виртуального хоста как
<VirtualHost *:80>
ServerName mywebapp.example.com
ProxyPass / http://www.example.com:8080/mywebapp
ProxyPassReverse / http://www.example.com:8080/mywebapp
ProxyRequests Off
<Proxy http://www.example.com:8080/mywebapp*>
Order deny,allow
Allow from all
</Proxy>
ErrorLog logs/mywebapp.example.com-error_log
CustomLog logs/mywebapp.example.com-access_log common
</VirtualHost>
Я изменил свой tomcat6 server.xml
файл и изменил первый соединитель, чтобы включить proxyName
и proxyPort
.
<!-- A "Connector" represents an endpoint by which requests are received
and responses are returned. Documentation at :
Java HTTP Connector: /docs/config/http.html (blocking & non-blocking)
Java AJP Connector: /docs/config/ajp.html
APR (HTTP/AJP) Connector: /docs/apr.html
Define a non-SSL HTTP/1.1 Connector on port 8080
-->
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
proxyName="mywebapp.example.com"
proxyPort="8080"
redirectPort="8443" URIEncoding="UTF-8"/>
Независимо от того, что я пытаюсь, когда я кладу mywebapp.example.com
в мой браузер он перенаправляет на mywebapp.example.com:8080/mywebapp
.
когда я хочу получить к нему доступ как mywebapp.example.com
и оставьте это в адресной строке браузера. Это сделало бы публикацию URL-адресов более удобной и т. Д.
Я уже настроил CNAME
в DNS
для mywebapp
.
www.example.com
на это не влияет.
журналы для httpd
нормально выглядят ... логи для tomcat6 ничего не показывают. Я знаю, что запрос попадает в нужное поле, потому что www.example.com:8080/mywebapp
работает (вместе с другими сайтами).
iptables
отключен, и поэтому, если SELinux
.
Что я делаю не так? Пожалуйста, порекомендуйте.
UPDATE:
Я пробовал добавить ProxyPreserveHost On
в конфиге vhost по одному из комментариев, но без кубиков. Когда эта строка добавляется и apache и tomcat перезапускаются, я не могу добраться до mywebapp.example.com
ни www.example.com:8080/mywebapp
. По сути, добавление этой конфигурации делает mywebapp вообще недоступным, но я знаю, что он все еще работает.
UPDATE 2:
Добавление tcpdump, взятого с сервера. Я показываю первое соединение, которое передается от pfsense
(прокси) в webserver
.
192.168.0.1 == pfsense
192.168.1.1 == webserver
192.168.2.1 == "internet"
192.168.0.1 > 192.168.1.1
GET / HTTP/1.1
Accept: text/html, application/xhtml+xml, */*
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
Host: mywebapp.example.com
DNT: 1
Via: 1.1 proxy.somecompany.com (squid/3.1.20)
X-Forwarded-For: 192.168.2.1
Cache-Control: max-age=259200
192.168.1.1 > 192.168.2.1
GET /mywebapp HTTP/1.1
Host: www.example.com:8080
Accept: text/html, application/xhtml+xml, */*
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
DNT: 1
Via: 1.1 proxy.somecompany.com (squid/3.1.20)
X-Forwarded-For: 192.168.2.1, 192.168.0.1
Cache-Control: max-age=259200
X-Forwarded-Host: mywebapp.example.com
X-Forwarded-Server: mywebapp.example.com
Connection: Keep-Alive
192.168.2.1 > 192.168.1.1
GET /mywebapp HTTP/1.1
Host: www.example.com:8080
Accept: text/html, application/xhtml+xml, */*
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
DNT: 1
Via: 1.1 proxy.somecompany.com (squid/3.1.20)
X-Forwarded-For: 192.168.2.1, 192.168.0.1
Cache-Control: max-age=259200
X-Forwarded-Host: mywebapp.example.com
X-Forwarded-Server: mywebapp.example.com
Connection: Keep-Alive
192.168.1.1 > 192.168.2.1
HTTP/1.1 302 Moved Temporarily
Server: Apache-Coyote/1.1
Location: http://mywebapp.example.com:8080/mywebapp/
Content-Length: 0
Date: Thu, 04 Apr 2013 05:14:44 GMT
192.168.2.1 > 192.168.1.1
HTTP/1.1 302 Moved Temporarily
Server: Apache-Coyote/1.1
Location: http://mywebapp.example.com:8080/mywebapp/
Content-Length: 0
Date: Thu, 04 Apr 2013 05:14:44 GMT
192.168.1.1 > 192.168.0.1
HTTP/1.1 302 Moved Temporarily
Date: Thu, 04 Apr 2013 05:14:44 GMT
Server: Apache-Coyote/1.1
Location: http://mywebapp.example.com:8080/mywebapp/
Content-Length: 0
Connection: close
Content-Type: text/plain; charset=UTF-8
192.168.2.1 > 192.168.1.1
GET /mywebapp/ HTTP/1.1
Accept: text/html, application/xhtml+xml, */*
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
DNT: 1
Connection: Keep-Alive
Host: mywebapp.example.com:8080
192.168.1.1 > 192.168.2.1
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Content-Encoding: gzip
Expires: 0
Cache-Control: no-cache,must-revalidate
X-App-Theme: default
Set-Cookie: JSESSIONID=81CE83D61454A8E75C222759FA118338; Path=/mywebapp
X-App: 1.395
X-App2: 1.508
X-App2-Session: e797c95b
X-App-CLI-Port: 36143
X-App2-CLI-Port: 36143
X-App2-CLI2-Port: 36143
X-Instance-Identity: MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjEfz8W2LiYRfrJQYH35uwtgQBpy0g6bTvBaTuARRpVLUmi+lnEfD/nVJY4GJoSfGzgnJAQ3MSqX+e1F4y2Jg5hwa2L0jibpb//BbfIMZkYZk8CtLMrkGvLC1nB7sghXupWOUOhWnzFq+a+LHSANNqfaMs9k6xJI6rvwIDAQAB
Content-Type: text/html;charset=UTF-8
Content-Length: 3879
Date: Thu, 04 Apr 2013 05:14:44 GMT
192.168.2.1 > 192.168.1.1
GET /mywebapp/static/e797c95b/css/style.css HTTP/1.1
Accept: text/css
Referer: http://mywebapp.example.com:8080/mywebapp/
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
Host: mywebapp.example.com:8080
DNT: 1
Connection: Keep-Alive
Cookie: JSESSIONID=81CE83D61454A8E75C222759FA118338
192.168.1.1 > 192.168.2.1
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Last-Modified: Mon, 25 Mar 2013 20:17:34 GMT
Expires: Fri, 04 Apr 2014 05:14:44 GMT
Accept-Ranges: bytes
Content-Encoding: gzip
Content-Type: text/css
Content-Length: 5763
Date: Thu, 04 Apr 2013 05:14:44 GMT
192.168.2.1 > 192.168.1.1
GET /mywebapp/static/e797c95b/css/color.css HTTP/1.1
Accept: text/css
Referer: http://mywebapp.example.com:8080/mywebapp/
Accept-Language: en-US
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)
Accept-Encoding: gzip, deflate
Host: mywebapp.example.com:8080
DNT: 1
Connection: Keep-Alive
Cookie: JSESSIONID=81CE83D61454A8E75C222759FA118338
Update 3:
Добавление моего текущего /etc/httpd/conf/httpd.conf
файл, чтобы показать обновления / изменения на данный момент.
<VirtualHost *:80>
ServerName mywebapp.example.com
ProxyPass / http://www.example.com:8080/mywebapp/
ProxyPassReverse / http://www.example.com:8080/mywebapp/
ProxyRequests off
RewriteEngine on
RewriteRule ^(/.*) http://www.example.com:8080/mywebapp/$1 [P]
# ProxyPreserveHost On
<Proxy http://www.example.com:8080/mywebapp*>
Order deny,allow
Allow from all
</Proxy>
ErrorLog logs/mywebapp.example.com-error_log
CustomLog logs/mywebapp.example.com-access_log common
</VirtualHost>
Прямо сейчас нет коробки для тестирования, но вы видите перенаправление 302, исходящее от вашего кота. Так всегда бывает, если вы запрашиваете индекс каталога без косой черты.
Попробуйте следующую конфигурацию ProxyPass и ProxyPassReverse:
ProxyPass / http://www.somesite.com:8080/mywebapp/
ProxyPassReverse / http://www.somesite.com:8080/mywebapp/
Обратите внимание на косую черту в конце. Это должно избежать временного перенаправления 302.
Изменить: для статического материала попробуйте добавить:
RewriteEngine on
RewriteRule ^(/.*) http://www.somesite.com:8080/mywebapp/$1 [P]
Это в основном говорит о том, что каждый запрос из корня вашего веб-сервера должен передаваться модулю прокси.
Зачем вам нужен Proxy
раздел?
<Proxy http://www.somesite.com:8080/mywebapp*>
Order deny,allow
Allow from all
</Proxy>
Похоже, что это перенаправление - это сгенерированный URL-адрес со стороны Tomcat.
Попробуйте добавить ProxyPreserveHost On
на ваш <VirtualHost *:80>
config?