我正在尝试让dnsmasq在Docker容器内作为DHCP服务器运行,向主机物理网络上的机器分配DHCP地址。我正在使用来自https://hub.docker.com/r/andyshinn/dnsmasq/的Alpine Linux 6MB容器。
它在主机机器上的53端口作为DNS服务器正常运行,但是在我期望DHCP存在的67/udp端口上没有任何监听。我使用dhcping 192.168.2.2
,但是得到"no answer"的回复。telnet 192.168.2.2 67
则返回"Connection refused"。
我的容器中的dnsmasq.conf文件如下所示:
interface=eth0
user=root
domain-needed
bogus-priv
no-resolv
local=/mydomain.io/
no-poll
server=8.8.8.8
server=8.8.4.4
no-hosts
addn-hosts=/etc/dnsmasq_static_hosts.conf
expand-hosts
domain=mydomain.io
dhcp-range=192.168.2.10,192.168.2.250,255.255.255.0,192.168.2.255,5m
# Have windows machine release on shutdown
dhcp-option=vendor:MSFT,2,1i
# No default route
dhcp-option=3
主机的静态地址为192.168.2.2。
我这样启动容器:
docker run -d --name dns -p 192.168.2.2:67:67/udp -p 192.168.2.2:53:53/udp sitapati/dns
这台运行Ubuntu 16.04的机器上没有防火墙。
我想到/尝试过以下方法:
- 是否因为容器中的eth0在完全不同的子网上有一个地址?(
docker inspect
告诉我它在桥接接口上的IP地址为172.17.0.2) - 它需要使用
--net host
吗?我尝试了那个,但它仍然没法工作。