问题描述
我们的内部网络保留了172.20.0.0/16范围供内部使用,而docker默认将172范围用于内部网络。通过为守护程序提供 bip
设置,我可以将网桥重置为192.168。
Our internal network has the range 172.20.0.0/16 reserved for internal purposes and docker uses the 172 range by default for its internal networking. I can reset the bridge to live in 192.168 by providing the bip
setting to the daemon:
➜ ~ sudo cat /etc/docker/daemon.json
{
"bip": "192.168.2.1/24"
}
➜ ~ ifconfig
docker0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.2.1 netmask 255.255.255.0 broadcast 0.0.0.0
但是,何时通过 docker network create
创建新的自定义网络,或在的
仍在172中创建,因此最终与 networks
部分中定义它们docker-compose.yaml 172.20
发生冲突:
However, when creating new custom networks via docker network create
or by defining them in the networks
sections of the docker-compose.yaml
these are still created in 172, thus eventually clashing with 172.20
:
➜ ~ docker network create foo
610fd0b7ccde621f87d40f8bcbed1699b22788b70a75223264bb14f7e63f5a87
➜ ~ docker network inspect foo | grep Subnet
"Subnet": "172.17.0.0/16",
➜ ~ docker network create foo1
d897eab31b2c558517df7fb096fab4af9a4282c286fc9b6bb022be7382d8b4e7
➜ ~ docker network inspect foo1 | grep Subnet
"Subnet": "172.18.0.0/16",
我了解我可以为 docker network create
提供子网值,但我宁愿在 192.168。*
下创建所有此类子网。
I understand I can provide the subnet value to docker network create
, but I rather want all such subnets created under 192.168.*
.
如何配置 dockerd
自动执行此操作?
How can one configure dockerd
to do this automatically?
推荐答案
对于发现此问题的任何人。
For anyone who found this question. Now it is possible.
$ docker -v
Docker version 18.06.0-ce, build 0ffa825
为docker daemon编辑或创建配置文件:
Edit or create config file for docker daemon:
# nano /etc/docker/daemon.json
添加行:
{
"default-address-pools":
[
{"base":"10.10.0.0/16","size":24}
]
}
重启dockerd:
# service docker restart
检查结果:
$ docker network create foo
$ docker network inspect foo | grep Subnet
"Subnet": "10.10.1.0/24"
适用于docker
您的 bip: 192.168.2.1/24
仅适用于bridge0。这意味着任何不使用-network
运行的容器都将使用此默认网络。
Your "bip": "192.168.2.1/24"
works for bridge0 only. It means that any container which run without --network
will use this default network.
这篇关于更改Docker自定义网络的默认子网的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!