15
7
It was well known that NetworkManager does not play well with dnsmasq
(ref: here). I've skimmed throught the lengthy discussion here but still not sure what the recommended way to deal with the situation is.
All that I want is to do is to use dnsmasq
to provide DNS and DHCP to my local network. What would be the recommended way in this case?
It seems the problem remains even for Ubuntu 14.04, even the bug is claimed to be fixed.
As work arounds, people are disabling the NM-enslaved dnsmasq-base
because the following reasons:
The NM-enslaved dnsmasq
uses hardcoded options (in C) that provide extremely limited functionality.
- It doesn't listen on ethX (
--listen-address=127.0.0.1
). So we can't use our servers as DNS servers for our local network PCs, i.e. it's completely useless for LANs. - It doesn't cache requests (
--cache-size=0
). No caching ==> no DNS queries speedup. This again is very significant for LANs as there are many concurrent users. - Finally, we also need the DHCP and TFTP functionality of dnsmasq, so even if NM+dnsmasq included a real DNS server, we'd have to run another dnsmasq
But I'm not sure if they still holds and/or how the fix has solve the problem(s). Further, none of them are very clear exactly what they did and how they did to solve their problem. I.e., the solution part is missing from the lengthy discussion. Can someone fill in the blanks please? I.e.,
The dnsmasq
provided out-of-box by Ubuntu is not working, on the server side, for the above reasons. And also, on the client side, "the dnsmasq installed on those Ubuntu laptops cannot do LAN DNS query from my DNS server", because "the (Ubuntu laptops') NetworkManager is causing them to have a weird 127.0.1.1 nameserver setting" (ref: DNS solution for LAN or local home network)
How to make dnsmasq to work smoothly with NetworkManager, so as to provide DNS and DHCP (and TFTP) to my local network, on both the server and client side?
TL'dr
for those seeking the answer. Of all the answers below, I found the simplest solution is @brad's, for the server side (still no good answer for the client side):
the only solution to the problem is to disable the NM-drive dnsmasq..., and install the "standard" dnsmasq and then configure it via its standard
/etc/dnsmasq.conf
configuration file.
2
Just for Googlers (like me): In newer versions of ubuntu dnsmasq-core inside NetworkManager is somewhat more friendly. See here: http://askubuntu.com/questions/233195/route-complete-tld-dev-for-example-to-127-0-0-1/233224#233224
– A. Rabus – 2014-08-24T11:25:20.760