Re: proxy pass и параметры в виде переменных
Emil Muratov
em на hotplug.ru
Вт Июл 27 13:22:38 MSD 2010
On 07/27/2010 12:46 PM, Igor Sysoev wrote:
> On Tue, Jul 27, 2010 at 12:12:21PM +0400, Emil Muratov wrote:
>
>>> Приветствую, All
>>>
>>> Настраивал nginx фронтом к плону,
>>> наткнулся на грабли. Нжинкс не эскейпит
>>> пробелы в запросах к бекэнду.
>>> Очень похоже на багу описанную здесь
>>> http://forum.nginx.org/read.php?21,107888 но немного в
>>> другой конфигурации. nginx version: nginx/0.8.44
>>>
>>> Если описать конфиг так:
>>>
>>>
>>>
>>> server {
>>> listen *:80;
>>> server_name tst.plone.lan site.plone.lan mgmt.plone.lan
>>>
>>> set $backend http://localhost:8080;
>>> set $zope_prefix
>>> /VirtualHostBase/http/$host/w/Site.Plone.Lan/Main/VirtualHostRoot;
>>>
>>> location / {
>>> proxy_set_header Host $host;
>>> proxy_pass $backend$zope_prefix$uri;
>>> }
>>> }
>>>
>>>
>>>
>>> То нжинкс передает запросы в зоп
>>> заменяя исходные %20 на "пробелы".
>>>
>>> В логах нжинкса запрос выглядит как
>>>
>>>
>>> 192.168.1.20 - - [23/Jul/2010:16:20:36 +0400] "GET
>>> /portal_javascripts/Plone%20Tableless/toc.js HTTP/1.1" 200 2129 "-"
>>> "Opera/9.80 (X11; Linux i686; U; en) Presto/2.5.29 Version/10.60"
>>>
>>>
>>>
>>> А в зоп он приходит так
>>>
>>>
>>> 127.0.0.1 - Anonymous [23/Jul/2010:16:23:39 +0400] "GET
>>> /VirtualHostBase/http/site.plone.lan/w/Site.Plone.Lan/Main/VirtualHostRoot/portal_javascripts/Plone
>>> Tableless/toc.js HTTP/1.0" 400 269 "http://lbg.pik.ru/kupit-kvartiru"
>>> "Mozilla/5.0 (compatible; Konqueror/4.4; Linux) KHTML/4.4.5 (like Gecko)
>>> SUSE"
>>>
>>>
>>>
>>> т.е. пробел в строке /Plone Tableless/
>>> передается в виде именно пробела.
>>>
>>> Если описать конфиг так:
>>>
>>>
>>> server {
>>> listen *:80;
>>> server_name tst.plone.lan site.plone.lan mgmt.plone.lan
>>>
>>> location / {
>>> rewrite ^/(.*)$
>>> /VirtualHostBase/http/$host/w/Site.Plone.Lan/Main/VirtualHostRoot/$1
>>> break;
>>>
>>> proxy_set_header Host $host;
>>> proxy_pass http://localhost:8080;
>>> }
>>> }
>>>
>>>
>>>
>>> то все работает нормально, все пробелы
>>> в урлах преобразуются в %20. Однако
>>> хотелось бы использовать переменные в
>>> proxy_pass и избавится от лишних реврайтов.
>>>
>>> Или я где-то что-то пропустил или одно
>>> из двух.
>>> Буду признателен за помощь.
>>>
>>
>> Поковырялся еще немного.
>> Если написать так:
>> proxy_pass $backend$zope_prefix$request_uri;
>>
>> то пробелы в урле нормально преобразуются в %20.
>>
>> А если так:
>> proxy_pass $backend$zope_prefix$uri;
>>
>> то соответственно не преобразуются и бекэнд отдает ошибку 400.
>>
>> Собственно вопрос - баг или фича? Неужели никто ничего не подскажет?
> Это фича. Вообще, тут достаточно такой конфигурации:
>
> location / {
> proxy_pass http://localhost:8080/VirtualHostBase/http/$host/w/Site.Plone.Lan/Main/VirtualHostRoot$request_uri;
> proxy_set_header Host $host;
> }
>
> без этих set'ов и rewrite'ов.
>
> "proxy_pass $backend$zope_prefix$request_uri" работает, потому что
> эти %20 есть в изначльном запросе.
>
Спасибо за комментарий.
Ну это слишком простой случай с одним локейшеном.
Некоторые урлы все же надо переписывать в разных местах, а конструкция
location / {
proxy_pass
http://localhost:8080/VirtualHostBase/http/$host/w/Site.Plone.Lan/Main/VirtualHostRoot$uri;
proxy_set_header Host $host;
}
в этом случае уже не работает.
set'ы для того чтобы в нескольких локейшенах не писать одно и тоже, хотя
вобщем-то без этого можно обойтись.
Но пробелы в $uri все равно не работают :( Видимо придется что-то
придумывать в обход.
Подробная информация о списке рассылки nginx-ru