Re: неправильный HTTP GET request с переменными в конфиге

Igor Sysoev igor на sysoev.ru
Пн Дек 21 18:56:32 MSK 2009


On Mon, Dec 21, 2009 at 10:51:38AM -0500, anatoly wrote:

> похоже nginx создает некорректные http requests когда в config server, location есть proxy_path с переменными, например
> proxy_pass        http://$1.site.com/;
> proxy_redirect    http://$1.site.com/ http://$1.ru.site.com/;
> ошибка происходит когда request url более сложный чем "/" вроде http://some.ru.site.com/more/complex.html
> происходит обрезание request url до "GET / HTTP/1.0" вместо корректного "GET /more/complex.html HTTP/1.0"
> 
> насколько я понимаю проблема в ngx_http_proxy_module.c 
> когда есть хоть одна переменная в proxy uri - инициализация модуля компилирует конфиг
> и заполняет список в конфиге cnf->proxy_lengths 
> и когда cnf->proxy_lengths не пустой - в качестве адреса запроса 
> берется conf->vars.uri которое формируется из proxy url, а не из request url и там всегда "/"
> если убрать проверку "if (plcf->proxy_lengths)" - запросы получаются правильные 
> вот так
> /**********************************************************************************/
> -- nginx/src/http/modules/ngx_http_proxy_module.c      (original revision)
> +++ nginx/src/http/modules/ngx_http_proxy_module.c      (working copy)
> @@ -899,7 +899,7 @@
> 
>      ctx = ngx_http_get_module_ctx(r, ngx_http_proxy_module);
> 
> -    if (plcf->proxy_lengths) {
> +    if (0) {
>          uri_len = ctx->vars.uri.len;
> 
>      } else if (ctx->vars.uri.len == 0 && r->valid_unparsed_uri && r == r->main)
> @@ -1005,14 +1005,14 @@
> 
>      u->uri.data = b->last;
> 
> -    if (plcf->proxy_lengths) {
> +    if (0) {
>          b->last = ngx_copy(b->last, ctx->vars.uri.data, ctx->vars.uri.len);
> 
>      } else if (unparsed_uri) {
>          b->last = ngx_copy(b->last, r->unparsed_uri.data, r->unparsed_uri.len);
> 
>      } else {
> -        if (r->valid_location) {
> +        if (r->valid_location && plcf->proxy_lengths==NULL) { 
>              b->last = ngx_copy(b->last, ctx->vars.uri.data, ctx->vars.uri.len);
>          }
> /**********************************************************************************/
> 
>  собственно вопрос - можно ли убрать проверку if (plcf->proxy_lengths)
>  и не зарезается ли при убирании какая-нибудь полезная функциональность nginx ?

Это не ошибка, а фича. Нужно писать

    proxy_pass        http://$1.site.com$request_uri;

или, начиная с 0.8.25:

    proxy_pass        http://$1.site.com;


-- 
Игорь Сысоев
http://sysoev.ru



Подробная информация о списке рассылки nginx-ru