Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Вопрос по тексту ошибки
On 17.01.2013 16:21, Михаил Монашёв wrote:
location ~* "^/(?<phost>[a-z0-9\-\.]+)/(?<puri>.*)" {
proxy_pass http://$phost:80/$puri;
proxy_set_header Host $1;
proxy_set_header Referer "http://$phost/";
в логе вот такая ошибка:
2013/01/17 17:47:58 [error] 3963#0: *8162 kevent() reported that connect() failed (60: Operation timed out) while
connecting to upstream, client: 80.239.243.119, server: i99.beon.ru, request: "GET
/ishop.top-kniga.ru/data/m_ishc/1084/1084845.jpg HTTP/1.1", upstream:
"http://91.206.106.43:80/data/m_ishc/1084/1084845.jpg", host: "i99.beon.ru", referrer:
"http://tanitakokyto.beon.ru/24898-872-tema-dlja-raznyh-anket.zhtml"
По идее nginx должен был отрезолвить ishop.top-kniga.ru , соединится
с полученным ip и запросить
http://ishop.top-kniga.ru/data/m_ishc/1084/1084845.jpg
Текст ошибки меня удивил. Его я его понял так: не удалось соединиться
с ip, в который отрезолвился ishop.top-kniga.ru. Но при это
показываются странные данные про апстрим:
upstream: "http://91.206.106.43:80/data/m_ishc/1084/1084845.jpg"
Хотя мне видится, что он должен быть таким:
http://ishop.top-kniga.ru/data/m_ishc/1084/1084845.jpg , ведь в
конфиге написано:
proxy_pass http://$phost:80/$puri;
, где $phost - это домен, а не ip.
Как получилось http://91.206.106.43:80/data/m_ishc/1084/1084845.jpg
понятно. Вопрос в том, правильно ли это?
судя по описанию
http://nginx.org/ru/docs/http/ngx_http_proxy_module.html#proxy_pass -
да, так и должно быть.
ведь доменное имя ishop.top-kniga.ru в общем случае может ресолвиться
в несколько разных IP, и если скрывать адрес апстрима, с которым не
удалось соединиться - толку от такого декоративного лога будет мало.
особенно, если апстрим будет задан отдельным блоком upstream { ... }
====================================================================
Имя сервера, его порт и передаваемый URI можно также полностью задать с
помощью переменных:
proxy_pass http://$host$uri;
или даже так:
proxy_pass $request;
В этом случае имя сервера ищется среди описанных групп серверов и если
не найдено, то определяется с помощью resolver?а.
====================================================================
--
Best regards,
Gena
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru
|