Я использую Raspberry Pi 3 с Ubuntu 18.04. В моей компании есть DNS-сервер и пара доменов с «.local». Я знаю, что технически это не правильно, и вместо этого это должен быть «.lan», потому что .local зарезервирован для многоадресных DNS. Но так оно и есть, и его нельзя легко изменить. Поэтому на моей машине с Windows я могу без проблем пинговать и просматривать эти доменные имена. На моем Ubuntu однако я не могу.
Я не могу использовать IP-адреса, потому что некоторые домены находятся на одной и той же машине, а веб-сервер IIS выясняет, что и куда идет.
Я искал, и это приходит довольно часто:
- https://smallbusiness.chron.com/resolving-local-ubuntu-38861.html
- Почему не разрешается ни один из моих локальных серверов?
- сервер Ubuntu не разрешает имена хостов локальной сети
Однако изменение /etc/nsswitch.conf не поможет мне. Я старался
- hosts: files mdns4_minimal [NOTFOUND = return] dns myhostname # default
- хосты: файлы днс
- hosts: files mdns4_minimal [NOTFOUND = continue] dns myhostname
- hosts: files mdns4 [NOTFOUND = return] dns myhostname
- hosts: files mdns4 [NOTFOUND = continue] dns myhostname
- hosts: files dns mdsn4_minimal myhostname
- хосты: днс
- несколько других
Ни один из которых не работал. Я попытался перезагрузиться после изменения тоже. Я пытался сказать avahi, что имя домена = alocal в /etc/avahi/avahi-daemon.conf не работает после перезапуска службы, не работает после перезагрузки. После того, как это не сработало, я попытался полностью отключить службу avahi-daemon.
sudo systemctl disable avahi-daemon
После перезагрузки я снова попробовал несколько перестановок в /etc/nsswitch.conf, но безрезультатно.
с моими текущими настройками в hosts (файлы днс) я получаю такой ответ:
dig login.name.local # not the actual name
; <<>> Dig 9.11.3-1ubuntu1.1-Ubuntu <<>> login.name.local
;; global options: +cmd
;; Got answer:
;; WARNING .local is reserved for Multicast DNS
;; You are currently testing what happens when an mDNS query is leaked to DNS
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 33538
;; flags: qr rd ra; QUERY: 1, ANSWER:0, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 65494
;; QUESTION SECTION:
;login.name.local. 0 IN A
;; Query time: 2msec
;; SERVER: 127.0.0.53#53(127.0.0.53)
;; WHEN: Thu Aug 23 10:51:50 CEST 2018
;; MSG SIZE rcvd: 56
Однако, когда я даю команду dig для прямого запроса к серверу, я получаю правильный ответ:
dig @dnsIP login.name.local
; <<>> Dig 9.11.3-1ubuntu1.1-Ubuntu <<>> login.name.local
; (1 server found)
;; global options: +cmd
;; Got answer:
;; WARNING .local is reserved for Multicast DNS
;; You are currently testing what happens when an mDNS query is leaked to DNS
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 57866
;; flags: qr aa rd ra; QUERY: 1, ANSWER:1, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 65494
;; QUESTION SECTION:
;login.name.local. 0 IN A
;; ANSWER SECTION:
login.name.local. 3600 IN A serverIP
;; Query time: 2msec
;; SERVER: dnsIP#53(dnsIP)
;; WHEN: Thu Aug 23 10:51:50 CEST 2018
;; MSG SIZE rcvd: 56
Эта версия Ubuntu использует netplan с сетевым менеджером. Правильный DNS-IP определенно есть в списке. (на самом деле это основной DNS.) Также dnsIp такой же, как serverIP, но это не должно быть проблемой.
Пинг или подключение через браузер, и такие не работают, конечно. Никто не использует запрос DNS.
Я в недоумении, что делать. Конечно, мы не можем переключиться на другое доменное имя. Я поместил имя сервера в / etc / hosts, но это только временное решение.
источник
Ответы:
Я столкнулся с очень похожей проблемой (если не точно такой же) в Linux Mint 19 (Tara). Мне удалось решить эту проблему, объединив 3 разных элемента информации. Кажется, все это связано с недавними изменениями в systemd-resolved.
Во-первых, да, мне нужно было настроить /etc/nsswitch.conf, как вы и ожидали. Пока днс приходит раньше, ты должен быть хорошим. Я закончил просто:
ссылка: /unix//a/457172/271210
До перехода на эту версию Mint это единственное, что мне нужно было сделать. Теперь я также сделал два других изменения, чтобы заставить его работать ...
После этого я настроил свой поисковый домен так, чтобы systemd-resolved работал так, как я хотел. Поэтому я отредактировал файл /etc/systemd/resolved.conf , параметр Domains в разделе [resolve] . В моем случае это выглядело так:
ссылка: /ubuntu//a/1031271/872881
Я также изменил конфигурацию avahi на что-то другое («mdns», если я правильно помню, но это не имеет значения). Это не должно требоваться, однако, из моего понимания. Просто добавлю для полноты.
Но ничего из этого не работало, пока я не назвал следующее:
ссылка: /ubuntu//a/938703/872881
После звонка все стало работать отлично и как положено!
Поэтому, возможно, мне не нужно было менять файл /etc/systemd/resolved.conf, но я сохранил это изменение, поскольку оно имело смысл и позволяло мне вводить только имя машины без полного доменного имени, чтобы разрешение DNS работало ,
источник
Принятый ответ не решил мою проблему. Это не имело ничего общего с avahi - у меня не был установлен сервис avahi. У меня есть система, настроенная на получение IP-адреса и параметров DNS-сервера от DHCP. Однако DNS, предоставленный dhcp, не проверялся на запросы с использованием .local
Реальная проблема заключается в том, что Ubuntu 18.4 имеет свой syv-файл resolv.conf, связанный с заглушкой, которая указывает на локальный хост для разрешения имен. Разрешение имен localhost dns означает, что система отказывается проверять предоставленный DNS-сервер на наличие имен .local, полагая (неправильно), что такие имена являются недействительными. Это настройка по умолчанию /etc/resolv.conf:
Содержимое заглушки (комментарии удалены):
«real» resol-conf имеет «правильную» настройку dns (из dhcp):
Чтобы система использовала предпочитаемый DNS-преобразователь вместо localhost, вы должны изменить символическую ссылку, указав /run/systemd/resolve/resolv.conf вместо /run/systemd/resolve/stub-resolv.conf:
Сразу после этого разрешение .local начало работать. нет необходимости перезагружать или перезапускать какой-либо сервис.
источник
Для меня рабочий путь для Ubuntu 18.04 - это:
Редактировать avahi conf:
и измените .local на .alocal:
затем откройте resolved.conf:
и раскомментируйте и отредактируйте домены:
и наконец перезапустите сервисы:
источник
Domains
в/etc/systemd/resolved.conf
(и перезапустить службу).Для меня работало добавление локального DNS в качестве сервера имен
/etc/resolvconf/resolv.conf.d/head
(как описано здесь ).Установите пакет resolvconf.
Отредактируйте
/etc/resolvconf/resolv.conf.d/head
и добавьте следующее:Перезапустите службу resolvconf.
Исправление должно быть постоянным.
источник
head
Файл является источником, используемым для генерации/run/resolvconf/resolv.conf
. Однако я бы не стал редактировать и этот файл.Моя ситуация была похожа, но несколько отличалась: мы используем имена серверов, как
myserver
в Windows, но это не работало в Ubuntu 16.04, и мне пришлось использоватьmyserver.mycompany.local
. После обновления до 18.04 я получил следующее поведение:Я просто должен был заменить
myserver.mycompany.local
сmyserver
в своих приложениях.источник