I'm using a Raspberry Pi 3 with Ubuntu 18.04. At my company we have a DNS server and a couple of domains with ".local". I know technically this isn't correct and it should be ".lan" instead, because .local is reserved for multicast dns. But that's the way it is and it can't easily be changed. So on my windows machine I can ping and browse to those domain names without trouble. On my Ubuntu however I can not.
I can not use IPs because some domains are on the same machine and the IIS webserver sorts things out what goes where.
I have searched and it comes up quite often:
- https://smallbusiness.chron.com/resolving-local-ubuntu-38861.html
- Why do none of my local servers resolve?
- ubuntu server not resolving LAN hostnames
However changing /etc/nsswitch.conf doesn't do the trick for me. I tried
- hosts: files mdns4_minimal [NOTFOUND=return] dns myhostname # default
- hosts: files dns
- 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
- hosts: dns
- a few others
None of which worked. I tried rebooting after a change too. I tried to tell avahi that the domain-name=alocal in /etc/avahi/avahi-daemon.conf, didn't work after service restart, didn't work after reboot. After this not working, I tried disabling the avahi-daemon service entirely.
sudo systemctl disable avahi-daemon
After a reboot I tried a couple of permutations in /etc/nsswitch.conf again, with no effect.
with my current settings in hosts (files dns) I get this response:
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
However when I instruct dig to query the server directly I get the correct answer:
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
This version of Ubuntu uses netplan with the network manager. The correct DNS IP is definitely in the list. (in fact it's the primary DNS.) Also the dnsIp is the same as serverIP, but that shouldn't be an issue.
Ping or connecting via browser and such don't work of course. None use the dns query.
I'm at a loss at what to do. Certainly we can't switch to a different domain name. I put the servername into /etc/hosts but that's just a temporary solution.
The accepted answer did not resolve my issue. It was nothing to do with avahi - I did not have avahi service installed. I have my system set to get its IP AND its DNS server settings from DHCP. However, the DHCP supplied DNS was not being checked for queries using .local
The real issue is that Ubuntu 18.04 has its resolv.conf sym-linked to a stub file that points to the localhost for name resolution. Localhost DNS name resolution means that the system refuses to check the supplied DNS server for .local names, believing (incorrectly) that such names are invalid. This is the default setup of /etc/resolv.conf:
content of the stub file is (comments removed):
the 'real' resolve conf has the 'correct' DNS setting (from DHCP):
In order to make the system use your preferred DNS resolver instead of localhost, you change the symlink to point to /run/systemd/resolve/resolv.conf instead of /run/systemd/resolve/stub-resolv.conf :
Immediately after this, resolution of .local started working. No need to reboot or restart any service.
I faced a very similar issue (if not exactly the same) on Linux Mint 19 (Tara). I've managed to solve it by combining 3 different pieces of information. It seems to all be related to recent changes with systemd-resolved.
First, yes I've needed to configure /etc/nsswitch.conf as you did and would expect. As long as dns comes before mdns you should be good. I ended with simply:
ref: https://unix.stackexchange.com/a/457172/271210
Prior to upgrading to this version of Mint, this is the only thing I needed to do. Now I also ended up making the below two other changes to get it working...
After that I've configured my search domain so systemd-resolved would work as I wanted. So I've edited the file /etc/systemd/resolved.conf, the Domains setting under the [resolve] section. In my case it ended up looking like:
ref: https://askubuntu.com/a/1031271/872881
I've also changed the avahi configuration to something else ("mdns" if I remember correctly, but it doesn't matter). It shouldn't be required however from my understanding. Just adding for completeness.
But none of it worked until I've called the following:
ref: https://askubuntu.com/a/938703/872881
After calling this, everything started working perfectly and as expected!
So it's possible I didn't really need to change the /etc/systemd/resolved.conf file but I kept this change since it made sense and allows me to only type a machine's name, without the complete FQDN, for DNS resolution to work.
For me working way for Ubuntu 18.04 is:
Edit avahi conf:
and change .local to .alocal :
then, open resolved.conf:
and uncomment and edit Domains:
and finally restart services:
What worked for me was adding the local DNS as a nameserver to
/etc/resolvconf/resolv.conf.d/head
(as described here).Install the resolvconf package.
Edit
/etc/resolvconf/resolv.conf.d/head
and add the following:Restart the resolvconf service.
The fix should be permanent.
For 20.04:
/etc/systemd/resolved.conf
&Domains=domain.local
service systemd-resolved restart
Thanks for this thread helping me get this working.
On Ubuntu Server 18.04/20.04 we were unable to resolve hostnames under our
corpname.local
domain, despite other name resolution taking place through our AD DNS server. What fixed it for me was to edit/etc/systemd/resolved.conf
and add:where
x.x.x.x
is the IP of our AD DNS server. Then runservice systemd-resolved restart
.This to me seems cleaner than the various solutions posted above which involve adding symlinks to change which
resolve.conf
the system is using etc.My situation was similar but somewhat different: We use server names like
myserver
on Windows but this did not work on Ubuntu 16.04 and I had to usemyserver.mycompany.local
. After upgrading to 18.04, I got the following behavior:I simply had to replace
myserver.mycompany.local
withmyserver
in my applications.This worked me on several Ubuntu systems:
https://github.com/lathiat/nss-mdns#etcmdnsallow
Essentially put two lines in
/etc/mdns.allow
:And you might need to change
/etc/nsswitch.conf
to use themdns4
module instead ofmdns4_minimal
. Notably this necessary on a Ubuntu Server box, but not on my Kubuntu desktop.