前言
最近有开发同学遇到一个问题,他所使用的主机所在网络环境也存在172.18.0.0/16的情况,跟docker_gwbridge默认使用172.18.0.0/16作为子网范围重复啦。
那么遇到这样的问题,我们可以通过修改docker_gwbridge的子网范围,以避免正常172.18.0.0/16网段终端的连接问题。
docker_gwbridge介绍
docker_gwbridge接口为使用多主机群覆盖网络的所有容器和任务提供默认网关功能。它是在每个码头工人主机上创建的,当它们加入集群时。如果接口docker_gwbridge的IP地址与网络上的地址冲突,可以逐个主机更改该地址。
docker_gwbridge是一个本地桥接网络,在以下两种情况会自动创建:
(1)初始化或者加入一个群集群时,用来在不同主机主机的不同节点间进行通信;
(2)再容器中的所有网络都不能访问外部时,码头工人会将docker_gwbridge网络加入到容器中,用来访问外部网络或者其他的集群节点。
修改docker_gwbridge
我们基于群集群来产生一个docker_gwbridge:
<代码> #码头工人群init 代码>
从上图中,我们可以看到docker_gwbridge默认使用172.18.0.0/16作为子网范围的。
重建docker_gwbridge网络
(1)我们先来查看下码头工人中所有网络简短信息:
<代码> #码头工人网络ls 代码>
(2)然后查看docker_gwbridge网络详细信息
<代码> #码头工人检查docker_gwbridge 代码>
<代码>… "容器":{ " ingress-sbox ": { “名称”:“gateway_ingress-sbox”, “EndpointID”:“8388305 ff33e4d4217518ae578693040f78dced947c36228e1dc7df55ae176a9”, :“MacAddress 02:42: ac: 12:00:02”, :“IPv4Address 172.18.0.2/16”, “IPv6Address”:“ } … 代码>
(3)再者删除上面中gateway_ingress-sbox
<代码> #码头工人网络断开docker_gwbridge gateway_ingress-sbox - f//需要加- f,否则会说找不到这个容器代码>
(4)删除原有的docker_gwbridge网络
<代码> #码头工人网络rm docker_gwbridge 代码>
(5)重新创建docker_gwbridge网络
<代码>网络创建\码头工人 ——子网172.20.0.0/20 \ ——网关172.20.0.1 \ - o com.docker.network.bridge.enable_icc=false \ - o com.docker.network.bridge.name=docker_gwbridge \ docker_gwbridge 代码>
(6)查看下主机网络信息
<代码> # ip添加| grep净代码>
扩展学习——群集群修改docker_gwbridge网络
要更改docker_gwbridge网络的子网,我们需要遵循如下操作:
<代码>改变这个接口的子网,停止任何经典容器连接到覆盖网络,离开群,删除网络,重新添加所需的地址,并重新启动经典容器如下(host-by-host基础上必须做):" 代码>
主要步骤如下:
(1)获取相关节点(管理员或工作者)角色的群连接令牌。
<代码> #码头工人群join-token工人代码>或<代码> #码头工人群join-token经理代码>
<代码>添加一个工人群,运行以下命令: 码头工人群加入——令牌SWMTKN-1-0lga4o5b38j8vg4obogubs1x7r0pctcsv38wynx0o3m0jaott6-c0hkjya6eavx9ye7xgwlj3bqi 192.168.246.176:2377 代码>
(2)保存任何叠加的经典容器的列表。这将用于在网络重新配置之前和之后停止和启动这些容器。
<代码> gwbridge_containers=$(码头工人网络检查docker_gwbridge——格式的{{$ k、v:美元=.Containers}} {{$ k}} {{printf“\ n”}}{{结束}}’| xargs -{}集装箱码头工人ls - f是任务=false - f id={}, {{. name}})格式& lt; br/祝辞echo $ {gwbridge_containers} 代码>
(3)停止使用docker_gwbridge的任何经典容器:
<代码>码头工人停止$ {gwbridge_containers} 代码>
(4)离开群
<代码>码头工人群离开代码>
(5)删除docker_gwbridge网络:
<代码>码头工人网络rm docker_gwbridge 代码>
(6)重新创建docker_gwbridge网络,设置所需的值:
<代码>网络创建\码头工人 ——子网172.20.0.0/20 \ ——网关172.20.0.1 \ - o com.docker.network.bridge.enable_icc=false \ - o com.docker.network.bridge.name=docker_gwbridge \ docker_gwbridge如何修改码头工人中gwbridge的地址吗?