11

在 Ubuntu Server 16.04 上启动 docker-ce (18.06.1-ce, build e68fc7a) 后,创建如下:

$ ifconfig
docker0   Link encap:Ethernet  HWaddr 02:42:fe:36:81:72
          inet addr:172.17.0.1  Bcast:0.0.0.0  Mask:255.255.0.0
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
      RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

不幸的是,我的电脑在这个网络上。这意味着一旦 docker 启动,我就会失去与服务器的 ssh 连接。

尝试 1

几个论坛都说要添加以下内容/etc/docker/daemon.json

{
  "bip": "192.168.1.1/24"
}

尝试 2,使用这个 SO 接受的答案

一种可行的解决方案正在运行:

sudo ip addr add dev docker0 192.168.1.1/24
sudo ip addr del dev docker0 172.17.0.1/16

资料来源:forums.docker.com

虽然这是一个可能的解决方案,但我必须在 docker 服务启动后才这样做。我不能做的事情,因为我同时失去了连接。

尝试 3,遵循@Light.G 的回答

添加-biptoExecStart行后,尝试启动 docker 给出(journalctl -xe):

-- Unit docker.socket has begun starting up.
Sep 11 11:13:19 PTLISLABHLC01 systemd[1]: Listening on Docker Socket for the API.
-- Subject: Unit docker.socket has finished start-up
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit docker.socket has finished starting up.
--
-- The start-up result is done.
Sep 11 11:13:19 PTLISLABHLC01 systemd[1]: docker.service: Start request repeated too quickly.
Sep 11 11:13:19 PTLISLABHLC01 systemd[1]: Failed to start Docker Application Container Engine.
-- Subject: Unit docker.service has failed
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit docker.service has failed.
--
-- The result is failed.
Sep 11 11:13:19 PTLISLABHLC01 systemd[1]: docker.socket: Unit entered failed state.
Sep 11 11:13:19 PTLISLABHLC01 polkitd(authority=local)[1062]: Unregistered Authentication Agent for unix-process:15666:32644036 (system bus name :1.56, object path /org/freedesktop/PolicyKit1/AuthenticationAgent, locale en_US.UTF-8) (disconnected from bus)

这里唯一的错误是你应该使用--bip而不是-bip. 检查接受的答案!

4

3 回答 3

15

不需要额外的实体:

  • 在启动 Docker 之前编辑 /lib/systemd/system/docker.service。--bip "192.168.1.1/24"在行尾添加ExecStart=/usr/bin/dockerd
  • systemctl daemon-reload
  • systemctl start docker

使用 Docker 17.03-ce 在 Ubuntu 16.04 上测试。

2018-09-13 编辑:
由于我们可能仍需要用户定义的桥接网络,因此仍然存在潜在问题。

默认情况下,网桥会分配一个范围为 172.[17-31].0.0/16 或 192.168.[0-240].20/20 的子网,该子网不与任何现有接口重叠。与默认桥接网络不同,用户定义的网络支持手动 IP 地址和子网分配。如果没有给出分配,那么 Docker 的默认 IPAM 驱动程序会分配私有空间中的下一个可用子网。

尽管他们说它不会与主机上的任何现有接口重叠,但您仍然遇到了这样的问题。因此,如果您需要用户定义的桥接网络,您最好为它们分配特定的子网。据我所知,没有用于自定义 IPAM 驱动程序默认池的参数。

于 2018-09-11T07:33:26.643 回答
5

我的解决方案是使用运行 shell 命令的服务来完成。

我创建了docker-network-setup.sh

sudo ip addr add dev docker0 192.168.1.1/24
sudo ip addr del dev docker0 172.17.0.1/16

chmod u+x docker-network-setup.sh以确保您可以执行它。

并且docker-network-setup.service

[Unit]
Description=Change docker0 default IP
# When systemd stops or restarts the docker.service, the action is propagated to this unit
PartOf=docker.service
# Start this unit after the docker.service start
After=docker.service

[Service]
# The program will exit after running the script
Type=oneshot
# Execute the shell script
ExecStart=/bin/bash /home/user01/docker-network-setup.sh start
# This service shall be considered active after start
RemainAfterExit=yes

[Install]
# This unit should start when docker.service is starting
WantedBy=docker.service

sudo cp docker-network-setup.service /etc/systemd/system并且服务已启用!

sudo systemctl daemon-reload如果您想立即测试服务,请不要忘记。

于 2018-09-07T15:19:15.543 回答
2

在我找到这个线程之前,我一直在努力使用不适用于我的 Docker 容器的AWS VPC 对等连接。

如果您使用的是AWS 172.17.xx 子网,它可能会与默认的 Docker 子网 ( 172.17.0.1/16 ) 冲突,因此这些子网之间将无法正常工作...

解决它的一种方法是移动到不同的 AWS 子网(由于遗留系统/配置,这并不总是可行的);

另一种方法是使用/etc/docker/daemon.json中的 bip 设置更改默认 Docker 子网(如上所述) - 类似于:

{
  "bip": "192.168.1.1/24"
}

最好的方法是避免在 AWS 中使用 172.17.xx 子网...

于 2021-06-29T16:15:39.573 回答