Docker 桥接主机网关不起作用

Docker 桥接主机网关不起作用

我的默认桥接网络无法正常工作。

因此我启动了 2 个容器,一个用于 mongodb,一个用于 ubuntu。这些是命令:

docker run -d ubuntu bash

docker run -d -p 27017:27017 mongo

这些是默认桥梁检查的结果。

[
    {
        "Name": "bridge",
        "Id": "eb4d37858eeafc8e05061f4a28d6b6a5754ad92476f5361f9c624636a335d1b4",
        "Created": "2023-06-03T00:50:02.603305706+10:00",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": null,
            "Config": [
                {
                    "Subnet": "172.17.0.0/16",
                    "Gateway": "172.17.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {
            "393c0b9bd82f7e7fd5469bae06016058a515cb9df7122b43a3a46c01cb28d992": {
                "Name": "ubuntu",
                "EndpointID": "8ed263215004e5b9deb18c23b4ff0aed2c5e60f862ac2d9118b9a6b9fb17100b",
                "MacAddress": "02:42:ac:11:00:03",
                "IPv4Address": "172.17.0.3/16",
                "IPv6Address": ""
            },
            "7d25013135cf2aaf4134c30ec4d87c3d5f88ade177c15461b0d5303e5ba530f3": {
                "Name": "mongoserver-test",
                "EndpointID": "b053f6f608675a23ef2c8541a0eb0a661270b49133596d901355bab4278ba166",
                "MacAddress": "02:42:ac:11:00:02",
                "IPv4Address": "172.17.0.2/16",
                "IPv6Address": ""
            }
        },
        "Options": {
            "com.docker.network.bridge.default_bridge": "true",
            "com.docker.network.bridge.enable_icc": "true",
            "com.docker.network.bridge.enable_ip_masquerade": "true",
            "com.docker.network.bridge.host_binding_ipv4": "0.0.0.0",
            "com.docker.network.bridge.name": "docker0",
            "com.docker.network.driver.mtu": "1500"
        },
        "Labels": {}
    }
 ]

在 ubuntu 容器中我安装了 nmap,当我尝试使用 nmap 检查端口时,使用以下命令:

nmap -p 27017 172.17.0.1

它显示端口为“已过滤”,我相信 mongodb 服务器正在接受传入连接但无法响应。为什么会发生这种情况?我该如何让它正常工作?此结果发生在 Linux 环境中。我已经在 osx 环境中进行了测试并且它正常工作。

注意:我尝试不使用 --link,因为我正在尝试找到一种集中式方法来执行此操作,而无需始终指定 --link。而且我不想使用 --network=host,因为这只是一次测试运行,将来我想尝试创建一个新容器并将其作为集中式集线器。我相信我可以通过以下方式指定:

docker run -d -p <new containerip>:27017:27017 mongo

相关内容