重启虚拟机之后,运行docker命令提示docker没有运行,然后启动docker就报错了。

[linmengmeng@localhost ~]$ docker ps
Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
[linmengmeng@localhost ~]$ sudo su
[sudo] password for linmengmeng: 
[root@localhost linmengmeng]# systemctl docker start
Unknown operation 'docker'.
[root@localhost linmengmeng]# systemctl start docker
Failed to start docker.service: Unit is not loaded properly: Invalid argument.
See system logs and 'systemctl status docker.service' for details.
[root@localhost linmengmeng]# systemctl status docker.service
● docker.service - Docker Application Container Engine
   Loaded: error (Reason: Invalid argument)
   Active: inactive (dead)
     Docs: https://docs.docker.com

May 11 11:06:26 localhost systemd[1]: docker.service has more than one ExecStart= setting, which is only allowed for Type=oneshot services. Refusing.
May 11 11:06:27 localhost systemd[1]: Cannot add dependency job for unit docker.service, ignoring: Unit is not loaded properly: Invalid argument.

但是可以查看docker版本,就很神奇!

在这里插入图片描述

然后查看docker运行状态:service docker status
在这里插入图片描述
提示的错误信息仍然跟上面启动报错的提示是一样的。

然后要查看具体错误,运行命令:/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock,输出了一大堆,可以看到有三行ERROR信息,但是说的是删除某个容器,但是没找到这个容器。是不是因为我之前运行了三个镜像,然后重启虚拟机的时候,镜像找不到了???然后导致启动docker报错???
在这里插入图片描述
这样想貌似也不对,启动的时候提示的是:docker.service has more than one ExecStart= setting, which is only allowed for Type=oneshot services. Refusing.

使用命令:systemd-analyze verify docker.service
显示的错误信息仍然是上面的错误:
在这里插入图片描述

看到有篇博客说到将ExecStart=后面加一个空行,但是在哪个文件里面修改这个却没有说。。。。。。

找了半天,发现docker.service文件路径为:/lib/systemd/system/docker.service

打印docker.service文件内容:cat /lib/systemd/system/docker.service
在这里插入图片描述
可以看到ExecStart确实有两个值。。。。。。

既然多了一个 那我就注释掉一个好了。。。。

在这里插入图片描述
然后重新加载sudo systemctl daemon-reload

重启:sudo systemctl restart docker

牛批!!!!!注释掉之后就好了

对于修改默认配置文件内容,官方建议如下: /usr/lib/systemd/system or /lib/systemd/system 包含默认配置.建议不要修改

但是我使用自定义配置启动docker却没有生效

首先切到/etc/systemd/system/ 路径下,看下原始文件:
在这里插入图片描述
1.我们手动建立配置文件
新建文件夹docker.service.d:sudo mkdir /etc/systemd/system/docker.service.d
新建文件docker.conf:sudo touch /etc/systemd/system/docker.service.d/docker.conf
在这里插入图片描述
修改docker.conf:sudo vi /etc/systemd/system/docker.service.d/docker.conf

然后重新读取验证
$ sudo systemctl daemon-reload
$ sudo systemctl restart docker
发现自定义的不好使。。。。。还是提示上面的问题, 然后注释掉默认配置文件中多的ExecStart就可以正常启动了。

参考:适合最新版docker自定义启动配置

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐