虚拟机重启之后docker无法启动,提示Loaded: error (Reason: Invalid argument)

重启虚拟机之后,运行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自定义启动配置

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
回答: 根据引用\[1\]和引用\[2\]的内容,可以看出docker.service启动失败,错误代码为1/FAILURE。根据引用\[3\]的内容,可以看出启动docker.service的控制进程退出时出现了错误代码。此外,根据问题描述,还提到了Loaded: error (Reason: Bad message)。根据这些信息,可以初步判断是docker.service启动时出现了错误,可能是由于错误的消息导致的。为了进一步了解问题的原因,建议查看"systemctl status docker.service"和"journalctl -xe"的详细信息,以获取更多的错误信息和上下文。 #### 引用[.reference_title] - *1* [在使用systemctl start docker启动失败时,使用systemctl status docker.service](https://blog.csdn.net/kavito/article/details/81200665)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Docker 启动报错 See “systemctl status docker.service“ and “journalctl -xe“ for details.](https://blog.csdn.net/chenxuezhou/article/details/123929006)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [See “systemctl status docker.service“ and “journalctl -xe“ for details启动报错](https://blog.csdn.net/yanghuadong_1992/article/details/111242976)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值