如何更改现有docker网络的配置

JSd*_*SdJ 5 networking docker

我有一个名为“VPN”的现有 (MacVLAN) docker 网络,我通常将希望在 VPN 上运行的 docker 容器附加到该网络。有两个运行 openvpn 的单个“主机”docker 容器,每个容器都有自己的 IP,并且我可以根据需要将其他容器附加到这些容器。

我最近搬家了,我的新路由器位于地址192.168.0.1。然而,老房子的路由器的网关为192.168.2.254,并且现有的 docker 网络已为此配置了子网掩码、IP 范围和网关。

如果我运行docker network inspect VPN它会给出:

[
    {
        "Name": "VPN",
        "Id": [anidea],
        "Created": [sometimenottolongago],
        "Scope": "local",
        "Driver": "macvlan",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "192.168.2.0/24",
                    "IPRange": "192.168.2.128/28",
                    "Gateway": "192.168.2.254"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {},
        "Options": {
            "parent": "enp5s0"
        },
        "Labels": {}
    }
]
Run Code Online (Sandbox Code Playgroud)

网络上有两台机器,我目前无法访问它们。两台机器都是一个容器,其他容器都附加到该容器上。我努力了:

  • 在新家庭网络的子网上使用新 IP 地址重新创建 Docker 容器。这不起作用,因为 docker 网络“VPN”只允许旧范围内的 IP。
  • 使用旧 IP 访问 docker 容器/机器。然后我得到一个超时;可能我需要设计一些IP路由之类的?这就是我的知识(如果有的话)开始变得模糊的地方。

我认为最好的方法是更新 docker 网络“VPN”,以便与新的网关/路由器/家庭网络很好地配合;我想更改IPAM["Config"]参数以更新新的网关和子网。但是,我无法在网上找到如何执行此操作(唯一出现的是如何更改默认docker 网络的默认设置)。

长话短说: 如何更改现有docker 网络的配置/参数?

如果最终这是一种不好的做法(例如,如果我可以按当前方式访问网络上的容器),我也愿意接受想法。

主机正在运行 ubuntu-server 20.04.1LTS。

提前致谢。

Mic*_*ski 3

最简单的方法是删除 VPN 网络,然后使用新参数但名称相同的方式重新创建它。如果您用于docker-compose up重新创建容器,请将该networks部分包含在您重新创建的第一个容器中。

首先,运行此命令删除现有网络:

docker network rm VPN
Run Code Online (Sandbox Code Playgroud)

然后将 macvlan 网络定义添加到yml您的第一个重新创建的容器中。这是networks我使用的部分,根据您的情况进行了一些调整:

networks:
  VPN:
    driver: macvlan
    enable_ipv6: true                   # if needed
    driver_opts:
      parent: eth0
    ipam:
      config:
        - subnet: 192.168.0.0/24
          gateway: 192.168.0.1
          ip_range: 192.168.0.8/30      # reserve some IP addresses for other machines
                                        # in that subnet - adjust as needed
        - subnet: xx:xx:xx:xx::/63      # put your IPv6 subnet here if needed
          gateway: xx:xx:xx:xx:xx::xx   # IPv6 (external) of your router
          
Run Code Online (Sandbox Code Playgroud)

或者,您可以更改新路由器配置以匹配旧路由器配置,并保持 macvlan VPN 不变。