Re: proxy pass - пропадают аргументы
green
nginx-forum на nginx.us
Вс Фев 27 20:59:54 MSK 2011
>> Когда делаю что-то подобное:
>>
>> location ~ ^/test(/.*\.php)$ {
>> proxy_pass http://cgi$1;
>> }
>>
>> То в запросе не передаются аргументы,
>> т.е. запрос:
>> http://server/test/xxx.php?param
>> преобразуется в:
>> http://cgi/xxx.php
>> (без аргументов)
>
> Если вы задаёте url в proxy_pass с
использованием переменных - вы
> задаёте его полностью. Поскольку
аргументы в формируемый url вы
> не включили - их там и нет.
Я бы не сказал что дело именно в
переменных. Дело вроде как в указании
пути. Т.е. если есть хотя бы / в конце, то
всё пропадает. Этого не написано в
документации. При этом rewrite ведёт себя
иначе (что описано в документации). И
из-за этого возникает конфуз с
пониманимем работы proxy_pass.
> Отдельно при таком способе задания
доставит необходимость
> самостоятельно следить за
корректностью получаемого url'а, в
> частности - escape'ингом спецсимволов.
Вышеприведённый конфиг
> замечательно ломается от запросов
вида "/test/blah%0D%OA.php".
Это мне кажется странным. Чем это
принципиально отличается от того,
когда nginx сам копирует URI вместо
выделенной мною части?
> Ну и в качестве дополнительного
бонуса - соответствующий upstream
> должен быть либо явно описан, либо
должен быть настроен resolver
> (и соответственно будет делаться resolve
регулярно).
Конечно же он описан как апстрим.
> Вообще, proxy_pass с переменными - он для
случаев, когда хочется
> странного, а не для нормальной работы.
Не надо его использовать
> без нужды.
Ещё раз. Описанное проявляется не
только с "переменной", но и с
"постоянной"!
>> Если же делать:
>>
>> location ~ \.php$ {
>> rewrite ^/test(/.*\.php)$ $1 break; # без него тоже
>> передаётся, но необрезанное
>> proxy_pass http://cgi;
>> }
>>
>> То всё передаётся. В документации
>> ничего вроде не нашёл про это, зато
там
>> написано, что если указывать proxy_pass
без
>> uri, то ему передастся запрос as-is, без
>> сокращения слешей и т.п.
>> Это баг или фича? И что меньшее зло -
rewrite
>> или добавлять $is_args$args в proxy_pass?
>
> Правильно - разделять код и данные, и
делать
Ну я же не могу сам все приложения
разрабатывать для себя. Давайте не
будет отвлекаться от темы и обсуждать
как надо писать web-приложения вместо
того, чтобы выяснять как использовать
уже существующие web-приложения. Или же я
не понял про что вы.
> location /test/ {
> proxy_pass http://backend/;
> }
А это работать не будет :). Т.к. стоит
слеш в конце.
>
> Если нужно проксировать только *.php, то
rewrite - меньшее зло.
Ну мне ещё причины хотелось бы
услышать, т.к. их чаще всего легче
запомнить и понять, чем набор юз-кейсов
для всех возможных случаев.
Posted at Nginx Forum: http://forum.nginx.org/read.php?21,177631,178853#msg-178853
Подробная информация о списке рассылки nginx-ru