我正在尝试在docker上使用相同的端口运行多个容器。
为此,我以brigde模式创建了一个网络并指定了一个子网。
docker network create -d --subnet 192.168.99.0/24 mynetwork
然后使用静态IP将docker容器连接到它。
docker run -i -t -d -p 2377:2377 -p 7946:7946 -p 4789:4789-name container image
docker network connect --ip 192.168.99.98 mynetwork container
在启动第二个容器后,我用三个容器(使用了不同的IP)做到了这一点:
Error response from daemon: driver failed programming external connectivity on endpoint container(...): Bind for 0.0.0.0:7946 failed: port is already allocated
就我而言,由于桥接模式,我不应该收到此错误。
答案 0 :(得分:0)
docker run -p
选项在主机系统上分配端口;它们在所有容器中共享,而与它们使用的Docker私有网络无关。这些也会与主机上运行的非Docker进程冲突。
如果您的目标只是能够在同一网络上的容器之间进行通信,则根本不需要-p
选项。他们可以使用彼此的--name
和容器内的服务正在监听的端口进行连接。
如果您尝试同时运行多个Docker容器堆栈,则需要确定主机上将路由到哪个特定实例端口2377的端口,并更改另一个容器的-p
选项。
几乎没有必要专门设置Docker内部私有IP地址(或根本不用担心它们)。我将删除那些--subnet
和--ip
选项。要在容器之间进行通信,请将它们置于如上所述的同一网络上;从外部,您需要一个(独特的)-p
选项。