Maxim Dounin
September 10, 2020 09:16AM
Hello!

On Thu, Sep 10, 2020 at 02:48:22PM +0300, Alexey Galygin wrote:

> доброго дня
>
> хотелось бы всё таки разобраться с вопросом резолвинга имён
>
> у нас есть докер-контейнер с nginx 1.18.0 с Docker Hub
> в него мы подкладываем в /etc/hosts файл свои несколько записей (условно):
>
> 10.0.3.4 docker_srv_a
> 10.0.3.5 docker_srv_b
> 10.0.3.6 docker_srv_c
>
> никакой разницы нет в дальнейшем использовании docker_srv_[a,b,c] в nginx.conf, при этом, srv_a и srv_b работают, а srv_c нет
>
> проверяли всё до знаков пунктуации — нет разницы в описании, но имя docker_srv_c nginx не видит
>
> пересборка, дублирование в родительской машинке в /etc/hosts, перезапуски nginx — ничего не помогает
> сам контейнер видит записи (через ping), nginx не видит одну из них — docker_srv_c
>
> все записи, но в особенности последняя резолвится (ping) в контейнере (docker exec -it nginx ping docker_srv_c), но последняя не резолвится в nginx
>
> в error log ошибка:
>
> 2020/09/10 13:24:58 [error] 22#22: *40 no resolver defined to resolve docker_srv_c, client: …, server: …, request: "GET /srv_c/api HTTP/1.1", host: "…"

Ошибка "no resolver defined" как бы говорит нам, что у вас
конфигурация требует динамического резолвинга адресов (то есть имя
используется вместе с переменными в proxy_pass). При динамичеком
резолвинге невозможно использовать системный резолвер, и
соответственно не используется файл /etc/hosts. Вместо этого надо
либо использовать IP-адреса непосредственно в конфиге nginx'а,
либо поднять DNS-сервер и указать его с помощью директивы
resolver.

> перевод строки ещё один на всякий случай добавлял в конец /etc/hosts — не помогло
>
> далее, поверх этих имён я просто повесил upstream'ы и, все три записи стали видны!
> убираю апстримы, пишу напрямую в proxy_pass http://docker_srv_c — не может разрешить имя

Цитата из документации (http://nginx.org/r/proxy_pass/ru):

: В значении параметра можно использовать переменные. В этом случае, если адрес
: указан в виде доменного имени, имя ищется среди описанных групп серверов и если
: не найдено, то определяется с помощью resolver’а.

> всё же какой-то глюк тут явно есть…
> что за внутренняя процедура в nginx relover по умолчанию и почему она не полностью следует hosts-файлу?
>
> почему резолвится только часть имён? да и что за чудеса, чем upstream так помогает резолвингу?

По умолчанию resolver не определён, и при динамическом резолвинге
будут работать только IP-адреса, имена upstream'ов и имена,
используемые в других частях конфига статически (так как для них
создаются неявные upstream'ы).

--
Maxim Dounin
http://mdounin.ru/
_______________________________________________
nginx-ru mailing list
nginx-ru@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-ru
Subject Author Posted

резолвятся не все имена host-файла

Alexey Galygin September 10, 2020 07:50AM

Re: резолвятся не все имена host-файла

Evgeniy Berdnikov September 10, 2020 08:02AM

Re: резолвятся не все имена host-файла

Alexey Galygin September 10, 2020 08:38AM

Re: резолвятся не все имена host-файла

Slawa Olhovchenkov September 10, 2020 08:40AM

Re: резолвятся не все имена host-файла

Maxim Dounin September 10, 2020 09:16AM

Re: резолвятся не все имена host-файла

Alexey Galygin September 10, 2020 10:08AM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 253
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready