auto-sync: 2026-05-23 13:33:44
This commit is contained in:
@@ -0,0 +1,265 @@
|
||||
# moziplus v2 用户手册(Agent 版)
|
||||
|
||||
> 本手册面向 Agent(庞统、诸葛亮),帮助快速理解和使用 moziplus v2 平台。
|
||||
> 人读版待后续补充。
|
||||
|
||||
## 1. 项目概况
|
||||
|
||||
- **定位**:多 Agent 任务编排平台(Blackboard 架构)
|
||||
- **版本**:v3.0(当前开发中)
|
||||
- **端口**:8083
|
||||
- **PM2 进程名**:`sanguo-moziplus-v2`
|
||||
- **前端**:http://localhost:8083/
|
||||
|
||||
### 目录结构
|
||||
|
||||
| 目录 | 说明 |
|
||||
|------|------|
|
||||
| `~/.openclaw/sanguo_projects/sanguo_moziplus_v2/` | 开发目录(改代码在这里) |
|
||||
| `~/.sanguo_projects/sanguo_moziplus_v2/` | 安装目录(运行在这里) |
|
||||
|
||||
⚠️ **禁止直接改安装目录**,除非用户明文要求。
|
||||
|
||||
## 2. 核心概念
|
||||
|
||||
### 数据模型
|
||||
|
||||
```
|
||||
Project(项目)→ Task(任务)→ SubTask(子任务/Stage)
|
||||
```
|
||||
|
||||
- **Project**:逻辑分组,对应一个 Git 仓库或业务领域。每个 Project 有独立的 `blackboard.db`
|
||||
- **Task**:用户的一个需求/意图。有状态管线:pending → claimed → working → review → done
|
||||
- **SubTask**:Agent 执行的原子任务,存储在 Task 的 `stages_json` 字段中
|
||||
|
||||
### 特殊项目
|
||||
|
||||
| 项目 ID | 说明 |
|
||||
|---------|------|
|
||||
| `_general` | 默认项目,无归属的任务放这里 |
|
||||
| `_mail` | 虚拟项目,Sanguo Mail 邮件的存储 |
|
||||
|
||||
### 任务状态
|
||||
|
||||
```
|
||||
pending → claimed → working → review → done
|
||||
↘ failed / blocked / cancelled / paused
|
||||
```
|
||||
|
||||
### 项目注册表
|
||||
|
||||
- `registry.db`(SQLite):项目注册信息
|
||||
- 自动发现:data 目录下的子目录有 `blackboard.db` 就会被发现
|
||||
- 手动注册:通过 API 或配置文件
|
||||
|
||||
## 3. 数据目录结构
|
||||
|
||||
```
|
||||
data/
|
||||
registry.db # 项目注册表(自动发现 + 手动注册)
|
||||
_general/ # 默认项目
|
||||
blackboard.db # SQLite 任务数据
|
||||
_mail/ # 邮件虚拟项目
|
||||
{project-name}/ # 用户项目
|
||||
blackboard.db
|
||||
```
|
||||
|
||||
## 4. 常用操作速查
|
||||
|
||||
### 4.1 部署脚本
|
||||
|
||||
所有脚本位于 `scripts/` 目录,支持 `--target=DIR` 和 `MOZIPLUS_V2_DIR` 环境变量覆盖安装路径。
|
||||
|
||||
| 操作 | 命令 | 说明 |
|
||||
|------|------|------|
|
||||
| 部署 | `scripts/deploy.sh` | 开发目录同步到安装目录 + 依赖安装 + 启动 |
|
||||
| 清空数据 | `scripts/reset-data.sh --confirm` | 停服务 → 清所有项目数据 → 重启 |
|
||||
| 指定项目清空 | `scripts/reset-data.sh --project=demo --confirm` | 只清指定项目 |
|
||||
| 卸载 | `scripts/uninstall.sh --confirm` | 完全卸载 |
|
||||
| 查看状态 | `scripts/status.sh` | 版本/PM2/健康检查/数据统计 |
|
||||
| 详细状态 | `scripts/status.sh -v` | 含每个项目的任务数 |
|
||||
| 备份 | `scripts/backup.sh` | 备份数据到 .backup/ |
|
||||
| E2E 准备 | `scripts/e2e-prepare.sh` | 备份 → 清理测试残留 → 干净环境 |
|
||||
| E2E 恢复 | `scripts/e2e-restore.sh` | 从备份恢复数据 |
|
||||
| 前端构建 | `scripts/build-frontend.sh` | 构建前端到 dist/ |
|
||||
|
||||
**路径覆盖示例**:
|
||||
```bash
|
||||
# 部署到自定义位置
|
||||
scripts/deploy.sh --target=/opt/moziplus_v2
|
||||
|
||||
# 用环境变量
|
||||
MOZIPLUS_V2_DIR=/opt/moziplus_v2 scripts/status.sh
|
||||
```
|
||||
|
||||
### 4.2 API 速查
|
||||
|
||||
基础 URL:`http://localhost:8083`
|
||||
|
||||
#### 项目管理
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/projects` | 项目列表(含 task_count 统计) |
|
||||
| POST | `/api/projects` | 创建项目 `{name, config_json}` |
|
||||
| GET | `/api/projects/{pid}` | 项目详情 |
|
||||
| PATCH | `/api/projects/{pid}` | 更新项目 |
|
||||
| DELETE | `/api/projects/{pid}` | 删除项目 |
|
||||
| POST | `/api/projects/{pid}/archive` | 归档项目 |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/move` | 移动任务到其他项目 |
|
||||
|
||||
#### 任务管理
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/projects/{pid}/tasks` | 任务列表(支持 `?status=done&archived=false` 过滤) |
|
||||
| POST | `/api/projects/{pid}/tasks` | 创建任务 `{title, description, must_haves}` |
|
||||
| GET | `/api/projects/{pid}/tasks/{tid}` | 任务详情 |
|
||||
| GET | `/api/projects/{pid}/tasks/{tid}?expand=all` | 含子任务/评论/产出/决策 |
|
||||
| PATCH | `/api/projects/{pid}/tasks/{tid}` | 更新任务(status/archived/priority 等) |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/claim` | 认领任务 |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/status` | 更新状态 `{status, note}` |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/archive` | 归档任务 |
|
||||
| POST | `/api/projects/{pid}/tasks/archive-done` | 归档所有已完成任务 |
|
||||
| GET | `/api/projects/{pid}/tasks/{tid}/progress` | 任务进度 |
|
||||
| GET | `/api/projects/{pid}/tasks/{tid}/events` | 任务事件列表 |
|
||||
| GET | `/api/projects/{pid}/summary` | 项目任务汇总 |
|
||||
|
||||
#### 评论 / 产出 / 决策 / 观测
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET/POST | `/api/projects/{pid}/tasks/{tid}/comments` | 评论 |
|
||||
| GET/POST | `/api/projects/{pid}/tasks/{tid}/outputs` | 产出 |
|
||||
| GET/POST | `/api/projects/{pid}/tasks/{tid}/decisions` | 决策 |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/observations` | 观测 |
|
||||
| GET/POST | `/api/projects/{pid}/tasks/{tid}/reviews` | 评审 |
|
||||
|
||||
#### Checkpoint(决策/验证/执行检查点)
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/projects/{pid}/tasks/{tid}/checkpoints` | 检查点列表 |
|
||||
| POST | `/api/projects/{pid}/tasks/{tid}/checkpoints` | 创建检查点 |
|
||||
| POST | `.../checkpoints/{cid}/approve` | 批准 |
|
||||
| POST | `.../checkpoints/{cid}/reject` | 驳回 |
|
||||
|
||||
#### Daemon
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/daemon/status` | 服务状态(版本/tick数/配置) |
|
||||
| POST | `/api/daemon/tick` | 手动触发一次 tick |
|
||||
| GET | `/api/daemon/sessions` | Agent session 列表 |
|
||||
|
||||
#### Mail(飞鸽传书)
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/mail` | 邮件列表(支持 `?from=x&is_read=false`) |
|
||||
| POST | `/api/mail` | 发送邮件 |
|
||||
| GET | `/api/mail/{mid}` | 邮件详情 |
|
||||
| PATCH | `/api/mail/{mid}` | 更新邮件(标记已读等) |
|
||||
| GET | `/api/mail/summary` | 邮件汇总 |
|
||||
| GET | `/api/mail/agents/list` | Agent 列表 |
|
||||
|
||||
#### SSE 实时事件
|
||||
|
||||
| 方法 | 端点 | 说明 |
|
||||
|------|------|------|
|
||||
| GET | `/api/events` | SSE 事件流(任务状态变更等) |
|
||||
|
||||
### 4.3 前端开发
|
||||
|
||||
```
|
||||
开发目录/src/frontend/ → 源码
|
||||
开发目录/src/frontend/dist/ → 构建产物
|
||||
```
|
||||
|
||||
**修改前端后的流程**:
|
||||
```bash
|
||||
# 1. 构建前端
|
||||
cd ~/.openclaw/sanguo_projects/sanguo_moziplus_v2/src/frontend
|
||||
npx vite build
|
||||
|
||||
# 2. 同步到安装目录
|
||||
rsync -a --delete \
|
||||
~/.openclaw/sanguo_projects/sanguo_moziplus_v2/src/frontend/dist/ \
|
||||
~/.sanguo_projects/sanguo_moziplus_v2/src/frontend/dist/
|
||||
|
||||
# 3. 重启服务
|
||||
pm2 restart sanguo-moziplus-v2
|
||||
```
|
||||
|
||||
注意:`npm run build` 会先跑 `tsc -b`,如果有 TS 类型错误会失败。跳过类型检查直接构建用 `npx vite build`。
|
||||
|
||||
### 4.4 后端开发
|
||||
|
||||
**修改后端后的流程**:
|
||||
```bash
|
||||
# 1. 在开发目录改代码
|
||||
# 2. 同步到安装目录(用 deploy.sh 或手动 rsync)
|
||||
# 3. 重启
|
||||
pm2 restart sanguo-moziplus-v2
|
||||
```
|
||||
|
||||
后端入口:`src/main.py`
|
||||
|
||||
## 5. 配置
|
||||
|
||||
配置文件:`config/default.yaml`
|
||||
|
||||
```yaml
|
||||
daemon:
|
||||
api_port: 8083
|
||||
tick_interval: 30 # tick 间隔(秒)
|
||||
max_global_agents: 5 # 最大并发 Agent 数
|
||||
```
|
||||
|
||||
## 6. 常见场景
|
||||
|
||||
### 创建一个任务
|
||||
|
||||
```bash
|
||||
curl -X POST http://localhost:8083/api/projects/_general/tasks \
|
||||
-H 'Content-Type: application/json' \
|
||||
-d '{"title": "调查 XXX", "description": "详细描述..."}'
|
||||
```
|
||||
|
||||
### 查看 Agent 工作状态
|
||||
|
||||
```bash
|
||||
# 服务状态
|
||||
curl http://localhost:8083/api/daemon/status
|
||||
|
||||
# 所有 session
|
||||
curl http://localhost:8083/api/daemon/sessions
|
||||
```
|
||||
|
||||
### 清空测试数据
|
||||
|
||||
```bash
|
||||
# 清空所有数据
|
||||
bash scripts/reset-data.sh --confirm
|
||||
|
||||
# 只清某个项目
|
||||
bash scripts/reset-data.sh --project=e2e-test --confirm
|
||||
```
|
||||
|
||||
### 归档已完成的任务
|
||||
|
||||
```bash
|
||||
# 单个任务
|
||||
curl -X POST http://localhost:8083/api/projects/{pid}/tasks/{tid}/archive
|
||||
|
||||
# 归档项目下所有已完成任务
|
||||
curl -X POST http://localhost:8083/api/projects/{pid}/tasks/archive-done
|
||||
```
|
||||
|
||||
## 7. 注意事项
|
||||
|
||||
1. **SQLite 并发**:每个项目独立 DB,写入串行化(asyncio.Lock),但多进程场景注意 busy_timeout
|
||||
2. **项目自动发现**:data 目录下有 `blackboard.db` 的子目录会被自动注册为项目
|
||||
3. **前端统计**:看板数字从 v2tasks 前端聚合(单数据源),不用后端 task_count
|
||||
4. **E2E 残留**:测试脚本会创建 `e2e-*` 项目,记得用 `reset-data.sh` 或 `e2e-prepare.sh` 清理
|
||||
5. **构建跳过 tsc**:`npx vite build` 跳过类型检查,`npm run build` 含 tsc(可能因已有 TS 错误失败)
|
||||
Reference in New Issue
Block a user