我已经应用了互联网上所有可用的解决方案,但我仍然不能运行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。

它发生在docker还没有启动的时候。

请检查docker状态

$ sudo systemctl status docker

然后启动并启用docker,并重新检查状态

$ sudo systemctl start docker && sudo systemctl enable docker && sudo systemctl status docker

这是它。现在检查docker的最后一步工作正常

$ sudo docker run hello-world

对于Linux运行

sudo dockerd

但是,如果你在mac上使用Docker客户端,它就不起作用了。试试下面的代码

$socat TCP-LISTEN:2376,reuseaddr,fork

https://forums.docker.com/t/using-pycharm-docker-plugin-with-docker-beta/8617/9

这个解决方案向世界开放了2376端口……由于TLS未启用,这是一个坏主意,因为同一网络上的任何人都可以劫持您的docker守护进程

在我的情况下,当做sudo dockerd——debug时,它显示了这个错误:“启动守护进程失败:初始化网络控制器错误:获取控制器实例错误:创建NAT链失败DOCKER: Iptables not found”

为了解决这个问题,我输入:

sudo update-alternatives --set iptables /usr/sbin/iptables-legacy
sudo update-alternatives --set ip6tables /usr/sbin/ip6tables-legacy
sudo systemctl start docker.service

欲了解更多详情,请访问:https://forums.docker.com/t/failing-to-start-dockerd-failed-to-create-nat-chain-docker/78269

只是增加了知识储备。我觉得这个视频很有用。我没有定义DOCKER_HOST。我有一个/etc/wsl.conf,它有:

[automount]
root = /
options = "metadata"

重启几次后,docker hello-world工作了。