我试图设置一个对接者dnsmasq容器,以便让我的所有码头容器查找域名,而不是有硬编码的if(如果它们在同一个主机上)。这解决了不能更改停靠器中的/etc/host文件容器这一事实的问题,这允许我通过更改dnsmasq容器引用的单个文件,轻松地一次性更新所有容器。
似乎有人已经为我做了艰苦的工作,并创建了一个dnsmasq集装箱。不幸的是,这对我来说“不管用”。我编写了一个bash脚本来启动容器,如下所示:
name="dnsmasq_"
timenow=$(date +%s)
name="$name$timenow"
sudo docker run \
-v="$(pwd)/dnsmasq.hosts:/dnsmasq.hosts" \
--name=$name \
-p='127.0.0.1:53:5353/udp' \
-d sroegner/dnsmasq在运行该目录之前,我创建了dnsmasq.hosts目录,并在其中插入了一个名为hosts.txt的文件,其内容如下:
192.168.1.3 database.mydomain.com不幸的是,每当我试图从内部ping该域时:
我总是收到ping: unknown host错误消息。
我尝试在没有守护进程模式的情况下启动dnsmasq容器,以便调试它的输出,如下所示:
dnsmasq: started, version 2.59 cachesize 150
dnsmasq: compile time options: IPv6 GNU-getopt DBus i18n DHCP TFTP conntrack IDN
dnsmasq: reading /etc/resolv.dnsmasq.conf
dnsmasq: using nameserver 8.8.8.8#53
dnsmasq: read /etc/hosts - 7 addresses
dnsmasq: read /dnsmasq.hosts//hosts.txt - 1 addresses我猜想在启动容器时没有正确地指定-p参数。有人能告诉我其他的码头容器查找DNS应该是什么吗?或者我想要做的事情是否真的不可能?
发布于 2014-04-11 13:06:19
需要更改dnsmasq服务的构建脚本,以便将绑定到服务器的公共IP,在本例中是192.168.1.12在我的eth0接口上
#!/bin/bash
NIC="eth0"
name="dnsmasq_"
timenow=$(date +%s)
name="$name$timenow"
MY_IP=$(ifconfig $NIC | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}')
sudo docker run \
-v="$(pwd)/dnsmasq.hosts:/dnsmasq.hosts" \
--name=$name \
-p=$MY_IP:53:5353/udp \
-d sroegner/dnsmasq在主机上(在本例中是ubuntu12),您需要更新resolv.conf或/etc/network/interfaces文件,以便将您的公共IP (eth0或eth1设备)注册为名称服务器。

当容器没有运行时,您可能希望将第二个名称服务器设置为google,方法是将该行更改为dns-nameservers xxx.xxx.xxx.xxx 8.8.8.8,例如没有逗号或另一行。
然后,如果更新了/etc/ sudo /etc/init.d/networking restart /接口文件,则需要重新启动网络服务,以便自动更新停靠器在构建过程中将复制到容器的/etc/ copy文件。
现在重新启动所有容器
sudo docker stop $CONTAINER_IDsudo docker start $CONTAINER_ID这将导致他们的/etc/ point文件更新,从而指向新的名称服务器设置。
DNS查找在您的所有码头容器(您作出更改后构建)现在应该使用您的dnsmasq容器!
另外,这意味着其他主机上的码头容器也可以利用此主机上的dnsmasq服务,只要主机的名称服务器设置设置为使用此服务器的公共IP即可。
https://stackoverflow.com/questions/23012273
复制相似问题