解决 N1 ARMBIAN Prometheus 服务启动失败问题

错误日志显示 prometheus.service 启动失败,核心原因是 WorkingDirectory 设置错误和服务文件语法错误。以下是详细解决方案:


检查并修复 WorkingDirectory

确保 WorkingDirectory 路径存在且正确。编辑服务文件:

bash 复制代码
sudo vi /etc/systemd/system/prometheus.service

检查 WorkingDirectory 路径是否与实际路径一致。例如:

ini 复制代码
WorkingDirectory=/sdb1/prometheus

创建目录并设置权限:

bash 复制代码
sudo mkdir -p /sdb1/prometheus
sudo chown -R prometheus:prometheus /sdb1/prometheus

修正服务文件语法

删除所有中文注释,并确保语法正确。示例配置:

ini 复制代码
[Unit]
Description=Prometheus Monitoring System
After=network.target

[Service]
User=prometheus
Group=prometheus
Type=simple
ExecStart=/sdb1/prometheus/prometheus \
    --config.file=/sdb1/prometheus/prometheus.yml \
    --storage.tsdb.path=/sdb1/prometheus/data \
    --web.listen-address=0.0.0.0:9090 \
    --web.enable-lifecycle
Restart=on-failure
RestartSec=5
WorkingDirectory=/sdb1/prometheus

[Install]
WantedBy=multi-user.target

创建 Prometheus 用户

确保用户和组存在:

bash 复制代码
sudo useradd -rs /bin/false prometheus

设置目录权限

确保目录归属和权限正确:

bash 复制代码
sudo chown -R prometheus:prometheus /sdb1/prometheus
sudo chmod +x /sdb1/prometheus/prometheus
sudo mkdir -p /sdb1/prometheus/data
sudo chown prometheus:prometheus /sdb1/prometheus/data

重新加载并启动服务

重新加载配置并启动服务:

bash 复制代码
sudo systemctl daemon-reload
sudo systemctl start prometheus.service
sudo systemctl status prometheus.service

查看日志:

bash 复制代码
sudo journalctl -u prometheus.service --no-pager -n 50

验证服务状态

检查进程和端口:

bash 复制代码
ps aux | grep prometheus
ss -tulnp | grep 9090
curl -v http://localhost:9090

验证服务文件语法

使用 systemd-analyze 检查语法:

bash 复制代码
sudo systemd-analyze verify /etc/systemd/system/prometheus.service

问题总结

问题 解决方案
WorkingDirectory 错误 检查路径并设置权限
服务文件语法错误 删除中文注释,修正语法
用户权限问题 创建用户并设置目录归属

执行完上述步骤后,再次检查服务状态。如果问题仍然存在,提供最新的日志以进一步分析。

相关推荐
sunfove7 小时前
光网络的立交桥:光开关 (Optical Switch) 原理与主流技术解析
网络
Kevin Wang7279 小时前
欧拉系统服务部署注意事项
网络·windows
min1811234569 小时前
深度伪造内容的检测与溯源技术
大数据·网络·人工智能
汤愈韬10 小时前
Full Cone Nat
网络·网络协议·网络安全·security·huawei
zbtlink10 小时前
现在还需要带电池的路由器吗?是用来干嘛的?
网络·智能路由器
桌面运维家10 小时前
vDisk配置漂移怎么办?VOI/IDV架构故障快速修复
网络·架构
dalerkd10 小时前
忙里偷闲叙-谈谈最近两年
网络·安全·web安全
汤愈韬11 小时前
NAT ALG (应用层网关)
网络·网络协议·网络安全·security·huawei
运维栈记12 小时前
虚拟化网络的根基-网络命名空间
网络·docker·容器
五仁火烧13 小时前
生产环境中配置了接口3000后,不能启动,改成8080后就可以
linux·网络·安全·vue