NatPierce & Sunshine systemctl 服务配置

38 阅读2分钟

概述

本文记录 natpierce 和 sunshine 两个服务的正确配置方法。

区别

环境适合运行图形支持
系统服务 (root)系统守护进程、硬件服务❌ 无图形环境
用户服务 (普通用户)GUI 程序、用户级守护✅ 完整图形环境

1. NatPierce 服务(系统级服务)

特点

  • 系统守护进程
  • root 权限运行
  • 无需图形界面

服务文件

[Unit]
Description=NatPierce Service
After=network.target

[Service]
Type=simple
ExecStart=/opt/natpierce/natpierce
Restart=always
RestartSec=5
User=root

[Install]
WantedBy=multi-user.target

文件位置

  • 服务文件:/etc/systemd/system/natpierce.service

2. Sunshine 服务(用户级服务)

特点

  • GUI 程序,需要图形环境
  • 登录后自启动
  • 关闭/崩溃自动重启

服务文件

[Unit]
Description=Sunshine Game Streaming
After=graphical-session.target

[Service]
ExecStartPre=/bin/sleep 3
ExecStart=/opt/sunshine/sunshine.AppImage
Restart=always
RestartSec=5

[Install]
WantedBy=graphical-session.target

Wayland 推荐使用 KWin screencast捕获;推荐使用最新预发布版本sunshine

文件位置

  • 服务文件:/etc/systemd/user/sunshine.service

参数说明

  • ExecStartPre=/bin/sleep 3 - 等待 3 秒确保图形环境就绪
  • Restart=always - 任何退出(包括手动关闭)都会自动重启
  • RestartSec=5 - 重启间隔 5 秒

常用命令

NatPierce (系统服务)

# 启动/停止/重启
sudo systemctl start natpierce.service
sudo systemctl stop natpierce.service
sudo systemctl restart natpierce.service

# 查看状态
sudo systemctl status natpierce.service

# 查看日志
sudo journalctl -u natpierce.service -f

# 开机自启
sudo systemctl enable natpierce.service

Sunshine (用户服务)

# 启动/停止/重启
systemctl --user start sunshine.service
systemctl --user stop sunshine.service
systemctl --user restart sunshine.service

# 查看状态
systemctl --user status sunshine.service

# 查看日志
journalctl --user -u sunshine.service -f

# 重新加载配置(修改 service 文件后需要)
systemctl --user daemon-reload

# 开机自启
systemctl --user enable sunshine.service

注意事项

  1. GUI 程序必须用用户服务:不能用系统服务运行 GUI,否则会因缺少显示环境变量而失败
  2. 用户服务需要在登录后运行:图形会话启动后才会运行
  3. 服务文件位置
    • 系统服务:/etc/systemd/system/
    • 用户服务:/etc/systemd/user/