# 项目服务管理面板 统一管理所有 Web 服务项目,提供状态检测、启动/停止控制、日志查看等功能。 ## 端口 - **服务端口**: 19013 - **访问地址**: http://localhost:19013 ## 功能 - 项目列表展示(状态、端口、版本) - 服务状态健康检测 - 启动/停止/重启控制 - 日志查看(实时滚动) - Git 仓库链接 ## 启动方式 ⭐ **重要:必须使用 `nohup + disown` 方式启动,脱离进程树!** ```bash cd ~/.openclaw/workspace-coder/works/project-panel nohup python3 app.py > logs/app.log 2>&1 & disown ``` ### 为什么需要 disown? 如果通过 OpenClaw 的 exec 启动服务,当 OpenClaw 清理进程时(如超时、重启),会发送 SIGTERM 杀掉所有子进程。 使用 `nohup + disown` 可以: 1. `nohup` - 让进程忽略 SIGHUP(终端关闭信号) 2. `disown` - 从 shell 进程树中移除,避免被连带杀掉 3. `> logs/app.log 2>&1` - 重定向输出到日志文件 ### ❌ 错误方式 ```bash # 不要用这种方式(会被 OpenClaw 杀掉) python3 app.py ``` ### ✅ 正确方式 ```bash nohup python3 app.py > logs/app.log 2>&1 & disown ``` ## 项目配置 项目配置在 `projects.json` 中,每个项目包含: ```json { "id": "project-id", "name": "项目名称", "ports": [19000], "directory": "works/project-dir", "start_cmd": "nohup python3 app.py > logs/app.log 2>&1 & disown", "health_url": "http://localhost:19000/api/health", "admin_url": "http://localhost:19000/admin", "git_repo": "http://192.168.2.8:12007/coder/project", "version": "v1.0.0" } ``` ## 端口规范 所有 Web 服务必须使用 **19000-19100** 端口范围: | 端口 | 项目 | |------|------| | 19000 | PDF翻译助手 V2 | | 19001 | LLM Index RAG | | 19009 | 碎片信息记录 | | 19010 | ParamHub Python | | 19013 | 项目服务管理面板(本服务) | | 19014 | Xian Favor 收藏系统 | | 19020 | AI对话系统 | | 19007 | LLM Proxy | | 19011 | 产品参数爬取系统 | | 19004 | 技术论坛 | | 19015 | 多智能体竞标调度系统 | ## API 接口 - `GET /api/projects` - 获取所有项目列表 - `GET /api/project/:id` - 获取单个项目详情 - `POST /api/project/:id/start` - 启动项目 - `POST /api/project/:id/stop` - 停止项目 - `POST /api/project/:id/restart` - 重启项目 - `GET /api/project/:id/logs` - 获取项目日志 ## 监控 服务监控由 `service-monitor` 负责,每 20 分钟检查一次,发送邮件通知。 ## 故障排查 ### 服务频繁停止? 检查是否使用了正确的启动方式: 1. 确认使用了 `nohup + disown` 2. 确认日志目录存在:`mkdir -p logs/` 3. 查看日志:`cat logs/app.log` ### OpenClaw 杀进程? 如果日志突然停止(约凌晨 01:10),可能是被 OpenClaw 清理进程杀掉了。 **证据:** - OpenClaw 日志:`[tools] exec failed: Command aborted by signal SIGTERM` - 服务日志最后记录时间:01:09 左右 **解决:** 使用 `disown` 脱离进程树。 ## Git 仓库 http://192.168.2.8:12007/coder/project-panel ## 更新日志 ### v1.0.1 - 添加 README.md 文档 - 记录正确的启动方式(nohup + disown) - 记录端口规范 ### v1.0.0 - 项目服务管理面板 - 状态检测、启动/停止控制 - 日志查看