我目前有一个正在运行的 docker 堆栈,其中的服务能够通过桥接网络相互通信。
即使入站连接有效(互联网 --> 容器),出站连接也无效:我无法从这些容器向互联网 wget;curl;etc。
我的主机在 Centos 上运行,考虑到与此类问题相关的在线帖子数量,我禁用了 firewalld 以检查是否是问题:不是。
CentOS Linux 7.9.2009 版
Docker 版本 1.13.1,构建 0be3e21/1.13.1
docker-compose 版本 1.28.5,构建 c4eb3a1f
networks:
mynetwork:
driver: bridge
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.19.0.0/16",
"Gateway": "172.19.0.1"
}
]
},
"Internal": false,
"Attachable": true,
"Containers": {
[...]
},
"Options": {},
"Labels": {
"com.docker.compose.network": "mynetwork",
"com.docker.compose.project": "myproject",
"com.docker.compose.version": "1.28.5"
}
带网址的卷曲:
curl www.tester.com
curl: (6) Could not resolve host: www.tester.com
Curl 使用 IP 工作。
好像跟DNS有关,但是我缺乏这方面的知识。如何调整我的配置以授予我的容器访问互联网的权限? (不设置网络:主机)
编辑:
将 DNS 设置到 docker-compose 文件中就像一个魅力。感谢@atline 的带领!
dns:
- 8.8.8.8
dns_search:
- domain.name
对于那些尽管将 DNS 设置为 docker 设置文件(daemon / docker.service / ...)但仍有类似问题的人,看起来 docker-compose 不使用 Docker “自定义”默认值;所以直接使用docker-compose
答案 0 :(得分:2)
您可以通过多种方式为容器配置 dns:
1.运行容器时添加dns:
docker run --dns 192.168.1.1 busybox nslookup google.com
2.配置 /etc/docker/daemon.json
为所有容器设置默认 dns:
{
"dns": ["192.168.1.1", "8.8.8.8"]
}
然后,sudo service docker restart
使其生效。
3.更改 systemd 脚本 /lib/systemd/system/docker.service
以包含 --dns
:
[Service]
ExecStart=/usr/bin/dockerd --dns 192.168.1.1 -H fd:// -H tcp://0.0.0.0:2375 --containerd=/run/containerd/containerd.sock
然后重启docker使其生效:
sudo systemctl daemon-reload
sudo systemctl restart docker
sudo systemctl status docker
注意:您应该使用真实的 dns 来替换 192.168.1.1 的值。