docker.service启动失败:Unit not found的原因及解决办法

作者:mrr 时间:2021-11-05 16:07:57 

背景

因为最近一直在折腾Kubernetes集群版本升级、Docker版本升级,所以不停的把测试环境安装、还原、升级、降级,简直乱的不行。终于,在测试Docker版本升级后,启动Docker时,遇到了docker.service: Unit not found。问题虽然不大,但是却折磨了我几个小时,所以在此mark一下。

操作系统:Red Hat Enterprise Linux 7

原因1:docker.socket

最初在启动docker时遇到问题,是因为docker.socket引起的,虽然记不清问题是表现为Unit not found还是执行systemctl start docker.service命令时hang住了,但是也一并记录在这里。

问题描述

我是从Docker 1.10.3升级到1.13.1版本,通过rpm包安装的。由于要保留自定义的一些Docker配置,所以在升级后,使用原来的/usr/lib/systemd/system/docker.service覆盖了新的docker.service。但是在1.10.3版本中,docker.service的[UNIT]里规定了Requires=docker.socket,也就是说,docker.service默认依赖于docker.socket,因为需要使用docker.socket来获取容器的信息。


[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network.target docker.socket
Requires=docker.socket


但是在1.13.1版本中,已经不再依赖于docker.socket了,所以系统里没有docker.socket,而我继续使用原来的docker.service,所以在启动的时候,就会出错。


解决办法


删除/usr/lib/systemd/system/docker.service的[UNIT]里包含的docker.socket,然后systemctl daemon-reload,最后systemctl start docker.service,发现启动成功了。


类似情况


如果是类似的情况,缺少docker.socket,但是新版本需要docker.socket。有两种方法可以解决该问题:



  • 可以卸载docker,再重新安装,即可出现docker.socket。或者


  • 创建一个/usr/lib/systemd/system/docker.socket文件,然后systemctl daemon-reload,最后systemctl start docker.service,即可启动成功。



/usr/lib/systemd/system/docker.socket文件如下:




[Unit]
Description=Docker Socket for the API
PartOf=docker.service
[Socket]
ListenStream=/var/run/docker.sock
SocketMode=0660
SocketUser=root
SocketGroup=docker
[Install]
WantedBy=sockets.target

原因2:flanneld.service

就如背景里描述的,我恰好在这台出问题的机器上,安装过Kubernetes,以及flannel,然后又删掉了我之前以为的“所有”相关的文件。正是由于flannel的文件没有删除干净,导致出现了docker.service: Unit not found的问题。

问题描述

在确定不是因为docker.socket的问题导致的之后,我第一反应就是删除flannel导致的,因为我了解flanneld.service与docker.service直接是有启动顺序的关联的:


[Unit]
Description=Flanneld overlay address etcd agent
After=network.target
After=network-online.target
Wants=network-online.target
After=etcd.service
Before=docker.service

真正困扰了我很久的是,/usr/lib/systemd/system/flanneld.service我已经删除了,也systemctl daemon-reload了,究竟还有哪个文件漏删了。

经过检查,/etc/systemd/system/flanneld.service依然存在,并且存在/etc/systemd/system/docker.service.requires目录,在该目录下包含了软连接flanneld.service,该软链接指向了真正的flanneld.service,从而实现了两个服务的启动顺序的关联。

定位该类问题,经常会用到的命令有:

  • systemctl list-unit-files 列出所有可用的Unit

  • systemctl list-units 列出所有正在运行的Unit

  • systemctl --failed 列出所有失败单元

  • systemctl mask httpd.service 禁用服务

  • systemctl unmask httpd.service

  • systemctl kill httpd 杀死服务

  • systemd-analyze critical-chain:分析启动时的关键链

  • systemd-analyze blame 分析启动时各个进程花费的时间

解决办法

使用systemctl unmask flanneld.service禁止flanneld服务,然后删除
/etc/systemd/system/docker.service.requires/flanneld.service,使用systemctl daemon-reload重新加载服务配置文件,最后systemctl start docker.service,发现docker启动成功了。

以上所述是小编给大家介绍的docker.service启动失败:Unit not found的原因分析及解决办法网站的支持!

标签:docker.service,启动
0
投稿

猜你喜欢

  • Godaddy主机如何设置开通Access数据库?

    2010-04-16 12:50:00
  • 让您的网站支持WIN7的JumpList和IE9的Pinned Sites

    2011-03-17 12:41:00
  • DedeCMS心情评论插件V2.0 beta(含心情排行)

    2009-02-19 20:28:00
  • 总结Centos7系统加固知识点

    2023-11-02 16:08:23
  • wordpress自定义url的方法【win2003主机】

    2011-08-31 20:02:53
  • 图解Web服务器和FTP服务器安全配置[1]

    2008-10-13 17:03:00
  • 详解linux里的backlog参数

    2022-08-10 22:22:07
  • 10月份西联汇款取款指南

    2007-11-03 13:16:00
  • 在 Linux 终端中查找域名 IP 地址的命令(五种方法)

    2021-04-11 06:14:16
  • VMware虚拟机中的linux复制粘贴详解

    2022-05-06 11:43:28
  • Google Adsense 搜索联盟问答

    2008-06-08 12:37:00
  • Apache下ModSecurity的安装启用与配置

    2023-07-15 18:13:15
  • VMware EXSI为虚拟机centos安装VMware Tools

    2023-11-04 06:04:36
  • 使用新云cms过程中的问题总结

    2008-04-09 13:05:00
  • Docker容器之间数据传输的实现

    2021-02-21 05:30:34
  • WordPress博客系统的安装和使用简介

    2008-04-23 07:40:00
  • 网站地址多出jdfwkey的问题解析及解决方法

    2010-08-11 12:01:00
  • 新蛋网AnthonyChow:做电子商务就应投资技术

    2009-10-27 11:47:00
  • 总结:FTP错误代码详解

    2007-12-24 09:42:00
  • 基于Docker搭建Redis主从集群的实现

    2022-10-23 05:09:44
  • asp之家 网站运营 m.aspxhome.com