Re: Аналог ProxyPassReverse
Alex Domoradov
alex.hha на gmail.com
Ср Ноя 4 19:13:34 UTC 2015
т.е. надо делать как то так?
server {
listen 80;
server_name www.example.net <http://imagesclr.example.net>;
location ~ \.jsp$ {
proxy_pass http://javaclr.example.net:8080;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_redirect http://javaclr.example.net:8080/ /;
}
location ~ \.asp$ {
proxy_pass http://aspclr.example.net <http://javaclr.example.net>
:8080;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_redirect http://aspclr.example.net
<http://javaclr.example.net>:8080/
/;
}
location ~ \.(png|jpg|js|css)$ {
proxy_pass http://s3aws.example.net <http://javaclr.example.net>;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_redirect http://s3aws.example.net <http://javaclr.example.net>/
/;
}
}
Из того что я понял apache лишь выполняет роль обычного reverse proxy,
просто вся логика у него реализована через .htaccess. например там есть
такие строки
RewriteRule (.*)\.(jsp|do)$ http://javaclr.example.net/$1.$2 [QSA,P]
RewriteRule (.*)\.asp$ http://aspclr.example.net/$1.asp [P]
RewriteRule ^(applet) http://javaclr.example.net/$1 [P]
RewriteRule
(.*)\.(jpg|gif|png|js|css|html|zip|jar|xml|class|pdf|swf|mp4|ico)$
http://images.example.net.s3-website-us-west-2.amazonaws.com/$1.$2 [NC,P]
ну и т.д.
2015-11-04 13:46 GMT+02:00 Igor Sysoev <igor на sysoev.ru>:
> On 04 Nov 2015, at 13:45, Alex Domoradov <alex.hha на gmail.com> wrote:
>
> Столкнулся с проблемой необходимости перевести apache на nginx. На данный
> момент в apache в настройках виртуалхоста есть директивы
>
> ProxyPassReverse / http://javaclr.example.net/
> ProxyPassReverse / http://imagesclr.example.net/
> ProxyPassReverse / http://aspclr.example.net/
> ProxyPassReverse / http://vsclr.example.net/
>
> В офф документации nginx -
> https://www.nginx.com/resources/wiki/start/topics/examples/likeapache/
> говорится, что достаточно использовать proxy_pass и передавать соотв хедеры.
>
> Но тут возникает вопрос, а как мне в одном location использовать несколько
> директив proxy_pass. Или единственный выход использовать map, что то вида
>
> map $host $proxy_host {
> default "";
> "~(javaclr|imagesclr|aspclr|vsclr)\.example\.net" "$host";
> }
>
> server {
> listen 80;
> server_name javaclr.example.net imagesclr.example.net
> aspclr.example.net vsclr.example.net;
>
> location / {
> proxy_pass http://$proxy_host;
> proxy_set_header X-Forwarded-Host $host;
> proxy_set_header X-Forwarded-Server $host;
> proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
> }
> }
>
>
> Аналог ProxyPassReverse - proxy_redirect:
> http://nginx.org/ru/docs/http/ngx_http_proxy_module.html#proxy_redirect
> Но, возможно, правильнее не валить всё в одну кучу, а сделать несколько
> серверов.
>
>
> --
> Igor Sysoev
> http://nginx.com
>
>
> _______________________________________________
> nginx-ru mailing list
> nginx-ru на nginx.org
> http://mailman.nginx.org/mailman/listinfo/nginx-ru
>
----------- следущая часть -----------
Вложение в формате HTML было извлечено…
URL: <http://mailman.nginx.org/pipermail/nginx-ru/attachments/20151104/7343df0b/attachment.html>
Подробная информация о списке рассылки nginx-ru