我第一次使用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-compose,以修复它:

终止docker-proxy进程 重启码头工人 再次启动docker-compose

其他回答

在Linux上,您可以运行sudo netstat -tulpn来查看该端口上当前正在监听的内容。然后,您可以选择配置该进程或Docker容器绑定到不同的端口,以避免冲突。

对于WINDOWS; 我杀死了docker使用的每个进程,并在services上重新启动docker服务。我的容器现在开始工作了。 它是关于Docker仍然在使用的端口,即使你当时没有使用。

别忘了最简单的解决办法....

重新启动计算机。

我已经尝试了上面的大部分方法,但仍然无法解决它。然后重启我的Mac,一切就恢复正常了。

只需重新启动计算机,docker服务就会重新启动

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

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

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

注意端口4000上的双映射。

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