我正在尝试设置一个 docker dnsmasq 容器,以便我可以让所有 docker 容器查找域名,而不是使用硬编码的 IP(如果它们在同一主机上)。这解决了一个问题,即无法更改 docker容器中的 /etc/hosts 文件,这使我可以通过更改 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 该域时:
- 主人
- dnsmasq 容器
- 同一主机上的另一个容器
我总是收到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
在启动容器时没有正确指定参数。有人可以告诉我其他 docker 容器查找 DNS 应该是什么,或者我想要做的事情是否实际上是不可能的?