我试图学习Docker,但我一直收到(对我来说)神秘的错误消息。

可能最简单的例子是试图打印我安装的Docker版本:

$ sudo docker version
Client version: 1.4.1
Client API version: 1.16
Go version (client): go1.3.3
Git commit (client): 5bc2ff8
OS/Arch (client): darwin/amd64
FATA[0000] Get http:///var/run/docker.sock/v1.16/version:
    dial unix /var/run/docker.sock: no such file or directory.
    Are you trying to connect to a TLS-enabled daemon without TLS?

我刚刚浏览了用户指南并严格遵循了每一步,所以我很惊讶我得到了这个消息……我现在该怎么办?

我刚刚注意到,如果我不使用sudo,我不会得到错误:

$ docker version
Client version: 1.4.1
Client API version: 1.16
Go version (client): go1.3.3
Git commit (client): 5bc2ff8
OS/Arch (client): darwin/amd64
Server version: 1.4.1
Server API version: 1.16
Go version (server): go1.3.3
Git commit (server): 5bc2ff8

当然,这不是一个解决方案,因为我可能需要在某个地方使用sudo。

我刚发现另一个页面说“如果你使用OS X,那么你不应该使用sudo。”我不知道他们是指这个例子,还是一般情况。


当前回答

当我用Jenkins创建Docker映像时,我也遇到了同样的问题。简单地将用户添加到docker组,然后重新启动docker服务,在我的情况下,我不得不重新启动Jenkins服务。

这是我得到的错误:

http:///var/run/docker.sock/v1.19/build?cgroupparent=&cpuperiod=0&cpuquota=0&cpusetcpus=&cpusetmems=&cpushares=0&dockerfile=Dockerfile&memory=0&memswap=0&rm=1&t=59aec062a8dd8b579ee1b61b299e1d9d340a1340: dial unix /var/run/docker.sock: permission denied. Are you trying to connect to a TLS-enabled daemon without TLS?
FATAL: Failed to build docker image from project Dockerfile
java.lang.RuntimeException: Failed to build docker image from project Dockerfile

Solution:

[root@Jenkins ssh]# groupadd docker
[root@Jenkins ssh]# gpasswd -a jenkins docker
Adding user jenkins to group docker
[root@Jenkins ssh]# /etc/init.d/docker restart
Stopping docker:                                           [  OK  ]
Starting docker:                                           [  OK  ]
[root@Jenkins ssh]# /etc/init.d/jenkins restart
Shutting down Jenkins                                      [  OK  ]
Starting Jenkins                                           [  OK  ]
[root@Jenkins ssh]#

其他回答

以我为例(Linux Mint 17),我做了各种各样的事情,我不确定其中哪些是完全必要的。

我将丢失的Ubuntu包包括在内:

$ sudo apt-get install apparmor lxc cgroup-lite

日志含义向组docker添加用户。

$ sudo usermod -aG docker ${USER}

启动守护进程(openSUSE只需要这个)

$ sudo docker -d

谢谢\归因


谢谢乌斯曼·伊斯梅尔,因为也许这只是最后一件事…

愚蠢的问题,你启动docker守护程序了吗?- Usman Ismail 12月17日15:04


还要感谢github@MichaelJCole为我提供的解决方案,因为当我阅读乌斯曼的评论时,我没有检查守护进程。

GitHub的评论:

sudo apt-get install apparmor lxc cgroup-lite
sudo apt-get  install docker.io
# If you installed docker.io first, you'll have to start it manually
sudo docker -d
sudo docker run -i -t ubuntu /bin/bash

感谢fredjean.net的帖子注意到丢失的包,忘记了默认的Ubuntu安装说明和谷歌关于其他方法

在Linux Mint上,缺省情况下没有安装cgroup-lite和lxc包。安装这两个程序后,我可以在基本映像中运行bash,然后构建并运行我的映像。


感谢brettof86对openSUSE的评论

我遇到了同样的问题,并尝试了各种方法来解决这个问题,修改.bash_profile文件,登录和退出,但没有任何运气。最后,重启我的机器解决了这个问题。

您可能还没有访问该文件的权限。 这发生在我把自己添加到dockergroup使用

sudo gpasswd -a user docker

但还没有注销。

要解决这个问题,您可以重新登录或使用 Sg docker "docker <subcommand>…"

如果您在/etc/group中的docker组中,您应该能够在不输入密码的情况下运行它。

https://dingyichen.wordpress.com/2015/02/05/docker-dial-unix-varrundocker-sock-no-such-file-or-directory-are-you-trying-to-connect-to-a-tls-enabled-daemon-without-tls/

Docker守护进程绑定到Unix套接字,而不是TCP端口。默认情况下,Unix套接字由root用户拥有,其他用户只能使用sudo访问它。Docker守护进程始终以根用户运行。

sudo groupadd docker
sudo usermod -aG docker $USER

登出并重新登录,以便重新评估组成员资格。

docker run hello-world

来源:以非root用户管理Docker

你需要做的是:

$boot2docker init
$boot2docker start

以下设置修复了这个问题:

$export DOCKER_HOST=tcp://192.168.59.103:2376
$export DOCKER_CERT_PATH=/Users/{profileName}/.boot2docker/certs/boot2docker-vm
$export DOCKER_TLS_VERIFY=1