虚拟机重启之后docker无法启动,提示Loaded: error (Reason: Invalid argument)
重启虚拟机之后,运行docker命令提示docker没有运行,然后启动docker就报错了。[linmengmeng@localhost ~]$ docker psCannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?[linmengmeng@localhos
重启虚拟机之后,运行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
就可以正常启动了。
更多推荐
所有评论(0)