dhcp: Default to using local DNS resolution

It's pointless to not include default DNS resolution for Neutron.
This adds a new config option (dnsmasq_local_resolv) which defaults
to 'True' and will allow for DNS name resolution to work out of
the box. The caveat is that if the 'dnsmasq_dns_servers' is set it
will override the 'dnsmasq_local_resolv' setting, thus allowing
operators to explicitly set their own DNS servers.

DocImpact: Default to using local DNS resolution with the DHCP agent.

Change-Id: I17a884f467d307432a06f67a9dd93ed2fa6081a3
Closes-Bug: #1466117
Signed-off-by: Kyle Mestery <mestery@mestery.com>
This commit is contained in:
Kyle Mestery 2015-06-17 14:46:47 +00:00
parent a6547e9cf0
commit 0de1d8d4ca
4 changed files with 32 additions and 2 deletions

View File

@ -85,6 +85,13 @@ DNSMASQ_OPTS = [
"The log contains DHCP and DNS log information and " "The log contains DHCP and DNS log information and "
"is useful for debugging issues with either DHCP or " "is useful for debugging issues with either DHCP or "
"DNS. If this section is null, disable dnsmasq log.")), "DNS. If this section is null, disable dnsmasq log.")),
cfg.BoolOpt('dnsmasq_local_resolv', default=True,
help=_("Enables the dnsmasq service to provide name "
"resolution for instances via DNS resolvers on the "
"host running the DHCP agent. Effectively removes the "
"'--no-resolv' option from the dnsmasq process "
"arguments. Adding custom DNS resolvers to the "
"'dnsmasq_dns_servers' option disables this feature.")),
cfg.IntOpt( cfg.IntOpt(
'dnsmasq_lease_max', 'dnsmasq_lease_max',
default=(2 ** 24), default=(2 ** 24),

View File

@ -307,7 +307,6 @@ class Dnsmasq(DhcpLocalProcess):
cmd = [ cmd = [
'dnsmasq', 'dnsmasq',
'--no-hosts', '--no-hosts',
'--no-resolv',
'--strict-order', '--strict-order',
'--except-interface=lo', '--except-interface=lo',
'--pid-file=%s' % pid_file, '--pid-file=%s' % pid_file,
@ -384,6 +383,11 @@ class Dnsmasq(DhcpLocalProcess):
cmd.extend( cmd.extend(
'--server=%s' % server '--server=%s' % server
for server in self.conf.dnsmasq_dns_servers) for server in self.conf.dnsmasq_dns_servers)
else:
# We only look at 'dnsmasq_local_resolv' if 'dnsmasq_dns_servers'
# is not set, which explicitly overrides 'dnsmasq_local_resolv'.
if not self.conf.dnsmasq_local_resolv:
cmd.append('--no-resolv')
if self.conf.dhcp_domain: if self.conf.dhcp_domain:
cmd.append('--domain=%s' % self.conf.dhcp_domain) cmd.append('--domain=%s' % self.conf.dhcp_domain)

View File

@ -1000,7 +1000,6 @@ class TestDnsmasq(TestBase):
expected = [ expected = [
'dnsmasq', 'dnsmasq',
'--no-hosts', '--no-hosts',
'--no-resolv',
'--strict-order', '--strict-order',
'--except-interface=lo', '--except-interface=lo',
'--pid-file=%s' % expected_pid_file, '--pid-file=%s' % expected_pid_file,
@ -1129,6 +1128,12 @@ class TestDnsmasq(TestBase):
('--log-facility=%s' % dhcp_dns_log)], ('--log-facility=%s' % dhcp_dns_log)],
network) network)
def test_spawn_cfg_no_local_resolv(self):
self.conf.set_override('dnsmasq_local_resolv', False)
self._test_spawn(['--conf-file=', '--no-resolv',
'--domain=openstacklocal'])
def test_spawn_max_leases_is_smaller_than_cap(self): def test_spawn_max_leases_is_smaller_than_cap(self):
self._test_spawn( self._test_spawn(
['--conf-file=', '--domain=openstacklocal'], ['--conf-file=', '--domain=openstacklocal'],

View File

@ -0,0 +1,14 @@
---
fixes:
- Prior to Mitaka, neither specifying DNS resolvers via the
'dnsmasq_dns_servers' option in the DHCP agent configuration file nor via
neutron subnet options causes the dnsmasq service to offer the IP address
on which it resides to instances for name resolution. However, the static
dnsmasq '--no-resolv' process argument prevents name resolution via dnsmasq
leaving instances without name resolution. In Mitaka+, the
'dnsmasq_local_resolv' option in the DHCP agent configuration file enables
(by default) the dnsmasq service to provide name resolution for instances
via DNS resolvers on the host running the DHCP agent by effectively
removing the '--no-resolv' option from the dnsmasq process arguments.
Adding custom DNS resolvers to the 'dnsmasq_dns_servers' option in the DHCP
agent configuration file disables this feature.