Bug日记:Linux中systemctl restart network失败问题,网络故障

日期

2023年10月25日


问题描述

在尝试使用 systemctl restart network 重启网络服务时,出现以下错误:

bash 复制代码
Job for network.service failed because the control process exited with error code.
See "systemctl status network.service" and "journalctl -xe" for details.

环境信息
  • 操作系统:CentOS 7.9
  • 网络服务network.service(传统网络服务)
  • 冲突服务NetworkManager(现代网络管理工具)

错误日志
  1. 查看服务状态

    bash 复制代码
    $ systemctl status network.service
    ● network.service - LSB: Bring up/down networking
       Loaded: loaded (/etc/rc.d/init.d/network; bad; vendor preset: disabled)
       Active: failed (Result: exit-code) since Wed 2023-10-25 10:00:00 CST; 5min ago
  2. 查看详细日志

    bash 复制代码
    $ journalctl -u network.service -xe
    Oct 25 10:00:00 localhost network[1234]: RTNETLINK answers: File exists
    Oct 25 10:00:00 localhost systemd[1]: network.service: control process exited, code=exited status=1

分析过程
  1. 初步猜测

    • 网络配置文件错误(如IP冲突、接口名称不匹配)。
    • 服务冲突(networkNetworkManager同时运行)。
  2. 排查步骤

    • 检查配置文件

      bash 复制代码
      cat /etc/sysconfig/network-scripts/ifcfg-eth0
      # 确认ONBOOT=yes,且接口名称与实际一致(如eth0、ens33)
    • 查看当前网络接口

      bash 复制代码
      ip a  # 发现实际接口为ens33,但配置文件中仍为eth0
    • 检查服务状态

      bash 复制代码
      systemctl is-active NetworkManager  # 发现NetworkManager正在运行
  3. 锁定原因

    • NetworkManagernetwork服务同时运行,争夺网络接口控制权。
    • 配置文件中的接口名称(eth0)与实际接口名称(ens33)不一致。

解决方案
  1. 临时解决冲突

    bash 复制代码
    # 停止NetworkManager服务
    sudo systemctl stop NetworkManager
    
    # 重启network服务
    sudo systemctl restart network
  2. 修复配置文件

    bash 复制代码
    # 修改接口名称(将eth0改为ens33)
    sudo vi /etc/sysconfig/network-scripts/ifcfg-ens33
  3. 永久禁用冲突服务(二选一)

    • 方案A :禁用NetworkManager(适合服务器环境)

      bash 复制代码
      sudo systemctl disable NetworkManager
      sudo systemctl enable network
    • 方案B :禁用network(适合桌面环境)

      bash 复制代码
      sudo systemctl disable network
      sudo systemctl enable NetworkManager

验证结果
  1. 确认服务状态

    bash 复制代码
    systemctl status network.service  # 显示active (running)
  2. 测试网络连接

    bash 复制代码
    ping 8.8.8.8  # 成功收到响应

预防措施
  1. 统一网络管理工具

    • 服务器环境:使用network.service,禁用NetworkManager
    • 桌面环境:使用NetworkManager,禁用network.service
  2. 配置文件检查清单

    • 接口名称与实际一致(使用ip anmcli device查看)。
    • 确保ONBOOT=yes,避免重启后网络未激活。
  3. 操作前备份

    bash 复制代码
    cp /etc/sysconfig/network-scripts/ifcfg-ens33{,.bak}

相关参考资料

备注:下次遇到类似问题,优先检查服务冲突和接口名称一致性!

相关推荐
孙克旭_2 小时前
PXE_Kickstart_无人值守自动化安装系统
linux·运维·自动化
皓月盈江3 小时前
Linux电脑本机使用小皮面板集成环境开发调试WEB项目
linux·php·web开发·phpstudy·小皮面板·集成环境·www.xp.cn
深井冰水3 小时前
mac M2能安装的虚拟机和linux系统系统
linux·macos
leoufung4 小时前
内核内存锁定机制与用户空间内存锁定的交互分析
linux·kernel
π大星星️4 小时前
HAProxy + Keepalived + Nginx 高可用负载均衡系统
运维·nginx·负载均衡
IT专业服务商5 小时前
联想 SR550 服务器,配置 RAID 5教程!
运维·服务器·windows·microsoft·硬件架构
忧虑的乌龟蛋5 小时前
嵌入式Linux I2C驱动开发详解
linux·驱动开发·嵌入式·iic·i2c·读数据·写数据
I_Scholar6 小时前
OPENSSL-1.1.1的使用及注意事项
linux·ssl
Johny_Zhao6 小时前
K8S+nginx+MYSQL+TOMCAT高可用架构企业自建网站
linux·网络·mysql·nginx·网络安全·信息安全·tomcat·云计算·shell·yum源·系统运维·itsm
稳联技术6 小时前
Ethercat转Profinet网关如何用“协议翻译术“打通自动化产线任督二脉
linux·服务器·网络