我有一个名为“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)
网络上有两台机器,我目前无法访问它们。两台机器都是一个容器,其他容器都附加到该容器上。我努力了:
我认为最好的方法是更新 docker 网络“VPN”,以便与新的网关/路由器/家庭网络很好地配合;我想更改IPAM["Config"]参数以更新新的网关和子网。但是,我无法在网上找到如何执行此操作(唯一出现的是如何更改默认docker 网络的默认设置)。
长话短说: 如何更改现有docker 网络的配置/参数?
如果最终这是一种不好的做法(例如,如果我可以按当前方式访问网络上的容器),我也愿意接受想法。
主机正在运行 ubuntu-server 20.04.1LTS。
提前致谢。
最简单的方法是删除 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 不变。
| 归档时间: |
|
| 查看次数: |
24700 次 |
| 最近记录: |