upstream could not be resolved...

Maxim Dounin mdounin на mdounin.ru
Ср Дек 8 21:09:19 MSK 2010


Hello!

On Wed, Dec 08, 2010 at 06:24:11PM +0300, Alexandre Snarskii wrote:

> On Wed, Dec 08, 2010 at 04:39:35PM +0300, Alexandre Snarskii wrote:
> > 
> > Hi!
> > 
> > Странная проблема вылезла: похоже, при какой-то фазе луны nginx
> > не может найти upstream, заданный в конфиге и лезет за ним в DNS. 
> > 
> > Задача - хитрый request routing в зависимости от переменных запроса,
> > поэтому запросы сначала передаются на fastcgi-скрипт, который 
> > делает необходимый анализ и отдает обратно x-accel-redirect 
> > на внутренний хост. 
> > 
> > Конфиг примерно такой: 
> > 
> >  http { 
> >   upstream sws-pod2 {  # с точным заданием номера порта тоже пробовал
> >    server a.b.c.d;
> >   }
> 
> Про то, что "с точным заданием номера порта пробовал" - это я погорячился,
> указания upstream sws-pod2:80 для этого недостаточно: в результате
> у upstream'а name становится "sws-pod2:80", а port по прежнему остается
> нулевым. В результате вторая часть следующущей проверки 
> (src/http/ngx_http_upstream.c, район 570'й строки) не удается ни в случае 
> просто upstream sws-pod2 ни в случае upstream sws-pod2:80: 
> 
>             if (uscf->host.len == host->len
>                 && ((uscf->port == 0 && u->resolved->no_port)
>                      || uscf->port == u->resolved->port)
>                 && ngx_memcmp(uscf->host.data, host->data, host->len) == 0)
>             {
>                 goto found;
>             }

Upstream с портом может появиться только при неявном задании через 
proxy_pass http://upstream:port/; в конфиге.  В честно описанных 
upstream-блоках порт - это свойство конкретного server'а в нём (и 
для разных серверов они могут быть разные).

Использование upstream-блоков в качестве банальной замены 
resolver'у - не предполагается.

> workaround: 
> 
>    location http://(.*):(.*) { 
> -    proxy_pass http://$1:$2/$request_uri$is_args$args;
> +    proxy_pass http://$1-$2/$request_uri$is_args$args;
>    }
> 
> и задавать порт на уровне имени upstream, например upstream sws-pod2-80.

Да, так будет работать.

Maxim Dounin



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