Linux下项目开机自启服务

在 Ubuntu(所有现代版本,16.04+)下,让可执行文件开机自启,最稳定、最推荐的方法是配置 systemd 服务

一、后台程序 / 服务:systemd 服务

1. 创建服务文件

复制代码
sudo nano /etc/systemd/system/你的服务名.service

2. 写入模板

bash 复制代码
# ===================== [Unit] 区块:服务整体说明、启动依赖 =====================
[Unit]
# Description:纯备注,给人/系统看的,说明这个服务是干啥的,随便改,不影响运行
Description=我的服务器

# After=network.target:意思是【等系统网络完全启动好了,再启动这个服务】
# 你的服务如果要对外提供接口、联网、监听端口,必须加这行;没网就启动会报错
After=network.target

# ===================== [Service] 区块:真正控制程序怎么跑 =====================
[Service]
# Type=simple:最常用模式,代表 ExecStart 里的程序是【主进程】,前台跑、常驻后台
# 大多数自研程序、接口服务、二进制可执行文件,都用这个
Type=simple

# ExecStart:重中之重!!程序启动的【绝对完整路径】
# 系统会按这个路径去找你的项目可执行文件或脚本,错一个字母、路径不对直接启动失败
ExecStart=/home/ubuntu24/PPOCR/mycode

# User=root:用 root 管理员身份运行这个程序
# 好处:有权限监听端口、读写任意文件夹、不会权限不足报错
# 注意:非必要不推荐,但本地内网服务没问题
User=root

# Restart=on-failure:程序崩了、闪退、报错退出,系统自动帮你重启
# 只在程序异常挂掉时重启;你手动stop,不会乱重启
Restart=on-failure

# RestartSec=3:程序挂掉后,等待3秒,再自动重启
RestartSec=3

# ===================== [Install] 区块:控制开机自启 =====================
[Install]
# WantedBy=multi-user.target:代表开机进入正常桌面/命令行多用户模式时,启动这个服务
# 标准通用配置,所有后台服务(ollama/接口/脚本)都写这个就行,不用改
WantedBy=multi-user.target

3. 生效 & 开机自启

bash 复制代码
# 重载 systemd
sudo systemctl daemon-reload

# 启用开机自启
sudo systemctl enable 你的服务名

# 立即启动(测试)
sudo systemctl start 你的服务名

# 查看状态
sudo systemctl status 你的服务名

4. 常用命令

bash 复制代码
#重载配置(改文件后必用)
sudo systemctl daemon-reload

#开机自启
sudo systemctl enable 我的服务

#取消开机自启
sudo systemctl disable 我的服务

#启动
sudo systemctl start 我的服务

#停止
sudo systemctl stop 我的服务

#重启
sudo systemctl restart 我的服务

#看运行状态
sudo systemctl status 我的服务

#实时看日志排错
journalctl -u 我的服务-f

二、日志输出成日志文件

1. 创建脚本

start.sh

bash 复制代码
#!/bin/bash

# 生成时间戳 年月日_时分秒,日志保存的路径
TS=$(date +%Y%m%d_%H%M%S)
LOG_DIR=/home/ubuntu24/server_log

# 正常日志+错误日志分开
exec >> ${LOG_DIR}/ocr_${TS}.log 2>> ${LOG_DIR}/ocr_err_${TS}.log

# 执行你的主程序
/home/ubuntu24/mycode

2. 路径替换

将自启动 服务.serviceExecStart下路径换成 脚本start.sh

再执行:

bash 复制代码
#重载配置(改文件后必用)
sudo systemctl daemon-reload

#重启
sudo systemctl restart 我的服务

#看运行状态
sudo systemctl status 我的服务
相关推荐
茉莉玫瑰花茶1 天前
工作流的常见模式 [ 1 ]
java·服务器·前端
米高梅狮子1 天前
第2章 docker容器
运维·docker·云原生·容器·架构·kubernetes·自动化
kidwjb1 天前
信号量在进程中的使用
linux·进程间通信
闵孚龙1 天前
Claude Code Ultraplan 远程多代理规划全解析:AI Agent、CCR远程容器、异步规划、状态机、计划传送与企业级自动化治理
运维·人工智能·自动化
南京码讯光电技术有限公司1 天前
工业无线AP选型指南:从WiFi 5到WiFi 6+5G CPE,如何构建全覆盖、零漫游、高可靠的智能工厂网络?
服务器·网络·5g
sulikey1 天前
个人Linux操作系统学习笔记2 - gcc与库的理解
linux·笔记·学习·操作系统·gcc·
二宝哥1 天前
Linux虚拟机网络配置
linux·运维·服务器
卧室小白1 天前
docker网络与服务编排与集群
运维·docker·容器
陳10301 天前
Linux:进程间通信 和 简单进程池
linux·运维·服务器
数字化顾问1 天前
(122页PPT)数字化架构的演进和治理(附下载方式)
java·运维·架构