繁体   English   中英

Docker MACVLAN 仅适用于出站

[英]Docker MACVLAN only works Outbound

我正在尝试为我的 docker 容器设置 MACVLAN。 我有一个全新的 Raspbian 和 Docker 安装,并按照 Docker 文档中概述的步骤创建了一个 MACVLAN: https ://docs.docker.com/network/network-tutorial-macvlan。

网络如下所示:

[
    {
        "Name": "pub_net",
        "Id": "782c49f79f549b11f04a6df98b8b2cbf52deef072e036306231309e44a1c9f3a",
        "Created": "2020-02-25T14:44:12.105402396+01:00",
        "Scope": "local",
        "Driver": "macvlan",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "192.168.178.0/24",
                    "Gateway": "192.168.178.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {
            "682a47a60a5478d19b8c6fc923e11c949f70c5c07fe4dc8d94a772524c2820a1": {
                "Name": "IoBroker",
                "EndpointID": "5e7068dd9330792a91e1f1f023bd052d91d1fa93f50a2eb670ef8be81b61587f",
                "MacAddress": "02:42:c0:a8:b2:02",
                "IPv4Address": "192.168.178.2/24",
                "IPv6Address": ""
            }
        },
        "Options": {
            "parent": "eth0"
        },
        "Labels": {}
    }

假设我有一个连接到该网络的 Alpine 容器。 从容器内部,我可以正常访问互联网和网络上的所有内容。 但是,我无法从外部访问 MACVLAN 内的任何容器。 我知道这通常在主机上不起作用,但我不是试图从主机访问容器,而是从我网络上的另一台机器访问。 容器的 IP 无法从外部访问。

如果我按照步骤允许主机访问 MACVLAN 上的容器(创建另一个 MACVLAN 并添加路由表条目),我可以从主机访问容器,但仍然不能从外部访问。

也许这更像是 Linux 网络问题而不是 Docker 问题?

Docker 版本:19.03.6 操作系统:Raspbian Buster 10,内核版本 4.19.97-v7+

是否有想法将不胜感激。

似乎这是 Raspbian 中使用的 Linux Kernel 版本中的 ARP 问题。 通过 sudo rpi-update 更新内核后,它现在对我有用。

实际上,自上周星期五以来,我遇到了同样的问题。

如果我 ping 主机试图访问 docker 容器,从容器内部(您的高山容器),我可以从外部访问容器,直到我重新启动容器本身。

我知道这不是解决方案,但可能有助于确定问题。

最佳航空

我有完全相同的问题。 我尝试使用 rpi-update 更新到 5.4 内核,但后来我无法安装 docker(它在 rpi-update 后停止工作)。 你是怎么安装docker的? 我尝试了一个干净的 Raspbian 安装,然后是 rpi-update,然后尝试了 docker install 但仍然没有运气。

Setting up docker-ce (5:19.03.9~3-0~raspbian-buster) ...
Job for docker.service failed because the control process exited with error code.
See "systemctl status docker.service" and "journalctl -xe" for details.
invoke-rc.d: initscript docker, action "start" failed.
docker.service - Docker Application Container Engine
   Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
   Active: activating (auto-restart) (Result: exit-code) since Tue 2020-05-19 21:42:58 BST; 21ms ago
     Docs: https://docs.docker.com
  Process: 2740 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock (code=exited, status=1/FAILURE)
 Main PID: 2740 (code=exited, status=1/FAILURE)
dpkg: error processing package docker-ce (--configure):
 installed docker-ce package post-installation script subprocess returned error exit status 1
Errors were encountered while processing:
 docker-ce
E: Sub-process /usr/bin/dpkg returned an error code (1)

对于您的问题,我有一个小的解决方法,因为我有同样的问题。

我做了一个全新的 omv 5 安装,之后我做了

sudo rpi-update 20354bebcc2a8448128f2348e19e155910d25122

“rpi-update”命令之后的字符串(哈希)是修复 ARP 问题的最新 4.19.118 内核

等docker安装问题解决后更新到5.X内核。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM