我已经应用了互联网上所有可用的解决方案,但我仍然不能运行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守护进程正在运行吗?


当前回答

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

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

其他回答

你就跑

sudo dockerd

Dockerd是docker容器的守护服务,因为它不是在后台运行,我们不能采取任何与服务相关的操作,需要重新启动。

将所有权分配给Docker Unix Socket

如果Docker的Unix套接字文件没有分配正确的所有权,也会出现“无法连接到Docker守护进程”错误。

1. 检查Docker Unix套接字的所有权:

sudo ls -la /var/run/docker.sock

2. 如有必要,授予用户所有权:

sudo chown [username]:docker /var/run/docker.sock

感谢Phonenixnap的回答

对于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守护进程

使用 Docker start <your_container_name>

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

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

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

我还收到了下面的错误消息,在安装docker并运行:docker run hello-world unix: /var/run/docker.sock无法连接到Docker守护进程。docker守护进程正在运行吗?

这是一个解决方案,对我很有效。 环境

Windows 10(别忘了在Windows上启用:设置>更新和安全>开发人员模式) Ubuntu 18.04 LTS Docker Desktop版本2.3.0.2 (45183) 在Docker Desktop中启用:在tcp: // localhost: 2375上不带TLS暴露守护进程 Docker Desktop也必须正在运行(连接到Docker Hub…登录即可)

安装ubuntu后,更新存储库

sudo apt-get update

通过HTTPS使用存储库

sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common

添加Docker官方GPG密钥:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

确保您现在拥有带有指纹的钥匙

sudo apt-key fingerprint 0EBFCD88

更新存储库

sudo apt-get update

更新docker存储库

sudo add-apt-repository "deb [arch = amd64] https://download.docker.com/linux/ubuntu $ (lsb_release -cs) stable "

再次更新存储库

sudo apt-get update

命令:5:18.09.9 ~ 3-0 ~ ubuntu-bionic安装docker

sudo apt-get install docker-ce = 5: 18.09.9 ~ 3-0 ~ ubuntu-bionic docker-ce-cli = 5: 18.09.9 ~ 3-0 ~ ubuntu-bionic containerd.io

命令设置DOCKER_HOST . conf

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

注意:把上面的命令放在你的配置文件中,从ubunto开始 例:echo "出口DOCKER_HOST = " tcp: / / 0.0.0.0:2375 " > > ~ / . bashrc

将用户添加到docker组

sudo usermod -aG docker $USER

重新启动ubuntu

(关闭并重新打开ubuntu窗口) 或运行:

source ~/.bashrc

测试安装(不要在docker命令之前使用更多的sudo(它会给出一个错误),用户“root”已经包含在docker组中)

docker run hello-world

应该会显示下面的消息

来自Docker的你好! 此消息显示您的安装似乎正在正常工作。

注意:如果失败,请重新执行命令:

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

参考:https://docs.docker.com/engine/install/ubuntu/ 会话:安装DOCKER引擎

其他版本的docker可以安装在ubuntu中,请使用下面的命令查看存储库: Apt-cache Madison docker-ce

然后安装所需版本的docker:

sudo apt-get install docker-ce = <VERSION_STRING> docker-ce-cli = <VERSION_STRING> containerd.io