我在Mac OS 10.8.5上安装了docker-machine 0.1.0和docker-compose 1.1.0。Docker-machine运行正常,可以通过Docker-machine ssh连接。

$ docker-machine ls
NAME   ACTIVE   DRIVER       STATE     URL                         SWARM
dev    *        virtualbox   Running   tcp://192.168.99.100:2376   

但是不能从docker-compose连接。

$ docker-compose up

无法在http+unix://var/run/ Docker连接到Docker守护进程。袜子——它在跑吗? 如果它位于非标准位置,则使用DOCKER_HOST环境变量指定URL。

我的Dockerfile和docker-compose。Yml在这里。

Dockerfile

FROM centos:centos7
DOCKER_HOST tcp://192.168.99.100:2376

docker-compose.yml

web:
  build: .

为什么不能连接?什么好主意吗?


当前回答

有人查过日志吗?

在我的例子中,/var/log/upstart/docker.log中的错误信息是:

Listening for HTTP on unix (/var/run/docker.sock) 
[graphdriver] using prior storage driver "aufs" 
Running modprobe bridge nf_nat failed with message: , error: exit status 1 
Error starting daemon: Error initializing network controller: Error creating default "bridge" network: can't find an address range for interface "docker0" 

值得一提的是,我打开了vpn,所以: $ sudo service openvpn stop $ sudo service docker restart $ docker-compose |start $ sudo service openvpn start 这就是解决办法。

其他回答

尝试先运行dockerd或sudo dockerdif来启动daemon。如果你用sudo启动dockerd,你可能也想用sudo运行docker-compose up。否则也没关系。

工作解决方案https://github.com/docker/compose/issues/4181

尝试使用以下命令重新启动docker环境:

systemctl restart docker

Docker机器正在运行。但是您需要导出一些环境来连接到Docker机器。默认情况下,docker命令行客户端试图使用http+unix://var/run/docker与守护进程通信。Sock(如错误消息中所示)。

使用eval $(docker-machine env dev)导出正确的环境变量,然后再试一次。你也可以运行docker-machine env dev来查看它将导出的环境变量。注意,其中一个是DOCKER_HOST,正如错误消息建议您可能需要设置的那样。

对我来说,我开始升级Docker,中途取消了。我没有注意到Docker没有运行(如果是的话,在我的Macbook的顶部导航栏上有一个图标,通过剩余电池,时间等)。一旦我启动它,并完成升级,docker-compose up再次工作!

解决这个问题的简单方法: 问题:

解决方案:

sudo chown $USER /var/run/docker.sock

答: