我第一次使用docker,我试图实现这个- https://docs.docker.com/get-started/part2/#tag-the-image

在一个阶段,我试图通过这个命令连接到localhost -

$ curl http://localhost:4000

哪个显示了这个错误-

curl: (7) Failed to connect to localhost port 4000: Connection refused

但是,我已经通过以下代码解决了这个问题-

$ docker-machine ip default
$ curl http://192.168.99.100:4000

在那之后一切都很顺利,但在最后一部分,我试图根据教程使用下面的行来运行应用程序……

$ docker run -p 4000:80 anibar/get-started:part1

但是,我得到了这个错误

C:\Program Files\Docker Toolbox\docker.exe: Error response from daemon: driver failed programming external connectivity on endpoint goofy_bohr (63f5691ef18ad6d6389ef52c56198389c7a627e5fa4a79133d6bbf13953a7c98): Bind for 0.0.0.0:4000 failed: port is already allocated.

当前回答

以上两个答案是正确的,但对我不适用。

我一直看到像下面这样的码头集装箱的空白 然后我尝试,docker容器ls -a之后,它显示了所有之前退出和运行的进程。 然后docker stop <容器id>或docker container stop <容器id>就不工作了 然后我尝试了docker rm -f <容器id>,它工作了。 现在,我尝试了docker容器ls -a,这个过程不存在。

其他回答

以上两个答案是正确的,但对我不适用。

我一直看到像下面这样的码头集装箱的空白 然后我尝试,docker容器ls -a之后,它显示了所有之前退出和运行的进程。 然后docker stop <容器id>或docker container stop <容器id>就不工作了 然后我尝试了docker rm -f <容器id>,它工作了。 现在,我尝试了docker容器ls -a,这个过程不存在。

对我来说,问题是将同一个端口映射两次。

由于参数化的码头运行,它最终像这样

docker run -p 4000:80 -p 4000:80 anibar/get-started:part1

注意端口4000上的双映射。

在这种情况下,日志没有提供足够的信息,因为它没有说明我是双映射的原因,并且在docker run命令返回失败后,端口不再绑定。

在Linux上“sudo systemctl restart docker”为我解决了这个问题

为了向IgorBeaz致敬,您需要停止运行当前容器。你需要知道当前的CONTAINER ID:

$ docker container ls

你会得到这样的结果:

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                  NAMES
12a32e8928ef        friendlyhello       "python app.py"     51 seconds ago      Up 50 seconds       0.0.0.0:4000->80/tcp   romantic_tesla   

然后停止容器:

$ docker stop 12a32e8928ef

最后你试着去做你想做的事,例如:

$ docker run -p 4000:80 friendlyhello

我也有同样的问题。转到Mac仪表板的Docker,然后单击重启。问题解决了。