我已经应用了互联网上所有可用的解决方案,但我仍然不能运行Docker。

我想在我的服务器上使用Scrapy Splash。

下面是我运行的命令的历史。

docker run -p 8050:8050 scrapinghub/splash
sudo docker run -p 8050:8050 scrapinghub/splash
sudo usermod -aG docker $(whoami)
sudo docker run -p 8050:8050 scrapinghub/splash
newgrp docker
sudo docker run -p 8050:8050 scrapinghub/splash
reboot
sudo docker run -p 8050:8050 scrapinghub/splash
docker run -p 8050:8050 scrapinghub/splash

你可以看到我试图重新启动我的服务器,但它没有帮助。

参见ps -aux | grep docker的输出

root@mani:/var/www/html# ps aux | grep docker
root      8524  0.0  0.8 127904 13964 ?        Ssl  17:21   0:00 /usr/bin/dockerd --raw-logs
root      8534  0.0  0.3  90588  5012 ?        Ssl  17:21   0:00 docker-containerd -l unix:///var/run/docker/libcontainerd/docker-containerd.sock --metrics-interval=0 --start-timeout 2m --state-dir /var/run/docker/libcontainerd/containerd --shim docker-containerd-shim --runtime docker-runc
root      8543  0.0  0.0   8812   764 pts/1    S+   17:21   0:00 grep --color=auto docker
root     16356  0.0  0.0  17200   964 pts/1    S    17:14   0:00 newgrp docker
root     20080  0.0  0.0  17200   964 pts/1    S    17:06   0:00 newgrp docker
root     30221  0.0  0.0  17200   964 pts/1    S    17:09   0:00 newgrp docker

但它给出了错误:

unix:///var/run/ Docker .sock无法连接到Docker守护进程。docker守护进程正在运行吗?


当前回答

这对你来说可能有点晚了,但希望它能帮助别人在码头工人的丛林中找到自己的路。 该问题可能来自tcp端口绑定问题 验证该文件是否存在

/etc/systemd/system/docker.service.d

这是默认的UNIX套接字监听覆盖文件。该文件实际上可能是空的,但我发现它存在的事实有时会导致一些头痛,就像你所面临的。 如果存在1.单击“确定”。然后2。如果不是,直接转到2。

1. $ sudo rm -rf /etc/systemd/system/docker.service.d

2. $ sudo systemctl deamon-reload

我发现这里的一些建议忽略了实际守护进程无法加载的错误

和docker一起玩的好朋友是

$ systemctl status docker.service

其他回答

首先,尝试使用sudo,因为当前用户可能没有访问权限与docker守护进程通信,即:

道克/ var /管理/袜子。

如果它仍然不能工作,那么,在安装之后,简单地停止docker守护进程:

sudo service docker stop

并且,运行以下命令在后台启动守护进程:

sudo nohup docker daemon -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock

为了使使用Docker更容易,您应该将您的用户名添加到 Docker users组。方法将用户添加到组中 命令如下:

sudo usermod -aG docker $USER

此外,docker Linux安装后步骤的官方文档中也提到了这一步。

Ubuntu 16.04用户可以执行以下步骤:

在文件/lib/systemd/system/docker中。服务的改变:

ExecStart=/usr/bin/dockerd fd://

to

ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375

在文件/etc/init.d /码头工人的改变:

DOCKER_OPTS=

to

DOCKER_OPTS="-H tcp://0.0.0.0:2375"

然后重启你的机器,开始使用docker。

对于gitlab CI运行node:lts image,我也遇到了同样的问题:

我只是重新启动docker守护进程和重新启动容器,它为我工作。

我看了所有的答案,没有找到任何接近我的情况。最后,问题是docker在我的系统上安装了两次,一次是通过snap,另一次是通过便利脚本。所以,如果有人遇到这个问题,一定要检查docker没有安装在多个地方,因为这会导致一些非常奇怪的行为。

使用 Docker start <your_container_name>

然后使用连接数据库 mssql -u <你的用户名> -p <你的密码>

如果在第一步中出现错误,那么docker将运行并执行第二步。

注意:我使用Mac作为我的主要操作系统,这对于基于Unix的操作系统可能是相同的答案。如果不是!提前说声抱歉。

我在root上运行并尝试如下,它起作用了:

service docker start

export DOCKER_HOST="tcp://0.0.0.0:2375"