Linux systemd 服务启动失败Main process exited, code=exited, status=203/EXEC

在使用 systemd 管理服务时,遇到服务启动失败并报错 Main process exited, code=exited, status=203/EXEC,通常意味着在执行服务时发生了错误,可能是由于配置文件、权限或可执行文件路径问题引起的。以下是详细的排查和解决步骤。

一、检查单元文件的配置

首先检查 systemd 单元文件(通常位于 /etc/systemd/system//lib/systemd/system/ 目录中)的配置。

  1. 示例单元文件

    复制代码
    [Unit]
    Description=My Custom Service
    After=network.target
    
    [Service]
    Type=simple
    ExecStart=/usr/bin/my-custom-service
    Restart=on-failure
    
    [Install]
    WantedBy=multi-user.target
  2. 检查 ExecStart 路径

    确保 ExecStart 中指定的可执行文件路径正确且存在。

    复制代码
    ls -l /usr/bin/my-custom-service
  3. 检查文件权限

    确保可执行文件具有执行权限。

    复制代码
    chmod +x /usr/bin/my-custom-service
二、验证可执行文件的有效性

确保可执行文件能够独立运行。

  1. 手动运行可执行文件

    尝试在终端中手动运行该文件,检查是否有错误输出。

    复制代码
    /usr/bin/my-custom-service
  2. 调试输出

    如果执行失败,检查错误信息并修复相应问题。

三、检查日志

systemd 会将详细的错误信息记录到日志中,通过 journalctl 命令查看相关日志。

  1. 查看服务日志

    复制代码
    journalctl -u my-custom-service.service
  2. 分析日志输出

    查找日志中的错误信息,通常会提供更详细的错误原因。

四、配置文件示例

以下是一个完整的示例,假设服务名为 my-custom-service

  1. 创建单元文件

    复制代码
    sudo nano /etc/systemd/system/my-custom-service.service
  2. 单元文件内容

    复制代码
    [Unit]
    Description=My Custom Service
    After=network.target
    
    [Service]
    Type=simple
    ExecStart=/usr/bin/my-custom-service
    Restart=on-failure
    
    [Install]
    WantedBy=multi-user.target
  3. 重载 systemd 配置

    复制代码
    sudo systemctl daemon-reload
  4. 启动服务

    复制代码
    sudo systemctl start my-custom-service
  5. 检查服务状态

    复制代码
    sudo systemctl status my-custom-service
相关推荐
m0_73812072几秒前
Solar月赛(应急响应)——攻击者使用什么漏洞获取了服务器的配置文件?
运维·服务器·安全·web安全·网络安全
咕噜签名分发冰淇淋4 分钟前
应用app的服务器如何增加高并发
运维·服务器
NotStrandedYet7 分钟前
信创国产Linux操作系统汇总:从桌面到服务器,百花齐放
linux·信创·国产化
爱喝水的鱼丶10 分钟前
SAP-ABAP:SAP ABAP OpenSQL JOIN 操作权威指南高效关联多表数据
运维·开发语言·数据库·sap·abap
特种加菲猫23 分钟前
从文件到文件描述符:理解程序与文件的交互本质
linux·笔记
闻道且行之26 分钟前
TTS语音合成|GPT-SoVITS语音合成服务器部署,实现http访问
服务器·gpt·http
懋学的前端攻城狮1 小时前
深入浅出Linux-01:系统化掌握基础操作
linux·后端
孙克旭_1 小时前
day064-kodbox接入对象存储与配置负载均衡
linux·运维·阿里云·负载均衡
forestqq2 小时前
zabbix平台无法删除已停用主机的处理案例
运维·服务器·zabbix
Java侠2 小时前
graylog6.3 docker-compose部署全流程
运维·docker·容器·graylog·docker compose