linux – 从Docker容器内部运行dnsmasq作为DHCP服务器
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux – 从Docker容器内部运行dnsmasq作为DHCP服务器,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1658字,纯文字阅读大概需要3分钟。
内容图文
![linux – 从Docker容器内部运行dnsmasq作为DHCP服务器](/upload/InfoBanner/zyjiaocheng/961/7e9531192b474a7f88ad30e8319559a3.jpg)
我正在尝试让dnsmasq作为Docker容器内的DHCP服务器运行,向主机物理网络上的机器发出DHCP地址.我正在使用https://hub.docker.com/r/andyshinn/dnsmasq/的Alpine Linux 6MB容器.
它可以作为主机端口53上的DNS服务器正常工作,但是没有任何东西监听端口67 / udp,这是我期待DHCP的地方.我用
dhcping 192.168.2.2,但得到“没有回答”. telnet 192.168.2.2 67返回“连接被拒绝”.
我在容器中的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告诉我在桥接接口上它是172.17.0.2)
>它需要使用–net host吗?我试过了,它仍然无法正常工作.
解决方法:
是的,容器将在虚拟子网(docker0桥接网络)上拥有自己的接口.因此,它将尝试在该子网上提供地址.
使用–net host为我工作,我使用类似以下命令的方式使DHCP服务器工作:
docker run --name dnsmasq2 -t -v /vagrant/dnsmasq.conf:/opt/dnsmasq.conf -p 67:67/udp --net host centos
–net host确保容器看起来使用主机的网络堆栈而不是它自己的网络堆栈.
dnsmasq -q -d --conf-file=/opt/dnsmasq.conf --dhcp-broadcast
我还需要将-dhcp-broadcast标志添加到容器内的dnsmasq,以使其实际在网络上广播DHCPOFFER消息.出于某种原因,dnsmasq试图单播DHCPOFFER消息,并使用ARP来尝试获取尚未分配的地址.
内容总结
以上是互联网集市为您收集整理的linux – 从Docker容器内部运行dnsmasq作为DHCP服务器全部内容,希望文章能够帮你解决linux – 从Docker容器内部运行dnsmasq作为DHCP服务器所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。