Centos 7.9 - Docker 容器无法访问互联网

时间:2021-06-29 18:56:13

标签: docker networking docker-compose

我目前有一个正在运行的 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

1 个答案:

答案 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 的值。