我在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: .

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


当前回答

我的设置有两个情况下这个错误:

我在容器内运行集成测试后,根用户创建的__pycache__文件对docker(告诉你原始问题)和docker-compose(告诉你关于docker主机含糊不清)是不可访问的; microk8s阻塞了我的端口,直到我停止它。

其他回答

作为根用户运行。Sudo docker-compose up -build

默认情况下,docker守护进程总是以root用户运行,因此你需要在docker命令前加上sudo。

如果在使用docker命令时不想使用sudo,可以创建一个名为docker的Unix组并向其添加用户。当docker守护进程启动时,它使docker组可以读/写Unix套接字的所有权。

创建docker组并添加用户:

创建docker组。 $ sudo groupadd docker 将您的用户添加到docker组。 $ sudo usermod -aG docker $USER 登出并重新登录,以便重新评估组成员资格。 验证您可以在没有sudo的情况下使用docker命令。 $ docker run hello-world

这个命令下载一个测试映像,并在容器中运行它。当容器运行时,它打印一条信息消息并退出。

上面列出的步骤来自Docker官方文档。

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

解决方案:

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

答:

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

Docker Compose需要特权访问,请确保在运行Docker - Compose命令之前提供特权访问。

你可能需要杀死当前的Docker进程并重新启动Docker Desktop,然后它才最有可能工作。

P.S.我在MacOS上,在重新启动并提供对Docker Desktop(4.10.1版本)应用程序的根访问后,得到与上面相同的错误,我能够成功地运行Docker compose命令,如下所示。

Docker-compose up -d——build