ai-engineering-init 1.8.0 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/agents/bug-analyzer.md +103 -0
- package/.claude/agents/code-reviewer.md +115 -5
- package/.claude/agents/code-scanner.md +145 -0
- package/.claude/agents/image-reader.md +154 -0
- package/.claude/agents/loki-runner.md +80 -0
- package/.claude/agents/mysql-runner.md +81 -0
- package/.claude/agents/requirements-analyzer.md +162 -0
- package/.claude/agents/task-fetcher.md +75 -0
- package/.claude/commands/dev.md +29 -0
- package/.claude/commands/next.md +31 -1
- package/.claude/commands/progress.md +23 -1
- package/.claude/hooks/skill-forced-eval.js +2 -0
- package/.claude/skills/analyze-requirements/SKILL.md +112 -0
- package/.claude/skills/fix-bug/SKILL.md +166 -0
- package/.claude/skills/yunxiao-task-management/SKILL.md +170 -258
- package/.claude/skills/yunxiao-task-management/templates//346/217/220/346/265/213/345/215/225/346/250/241/346/235/277.html +17 -0
- package/.codex/skills/analyze-requirements/SKILL.md +112 -0
- package/.codex/skills/fix-bug/SKILL.md +166 -0
- package/.codex/skills/yunxiao-task-management/SKILL.md +170 -258
- package/.codex/skills/yunxiao-task-management/templates//346/217/220/346/265/213/345/215/225/346/250/241/346/235/277.html +17 -0
- package/.cursor/agents/bug-analyzer.md +102 -0
- package/.cursor/agents/code-reviewer.md +80 -97
- package/.cursor/agents/code-scanner.md +145 -0
- package/.cursor/agents/image-reader.md +154 -0
- package/.cursor/agents/loki-runner.md +80 -0
- package/.cursor/agents/mysql-runner.md +81 -0
- package/.cursor/agents/project-manager.md +1 -1
- package/.cursor/agents/requirements-analyzer.md +141 -0
- package/.cursor/agents/task-fetcher.md +75 -0
- package/.cursor/hooks/cursor-skill-eval.js +10 -0
- package/.cursor/rules/skill-activation.mdc +7 -0
- package/.cursor/skills/analyze-requirements/SKILL.md +112 -0
- package/.cursor/skills/fix-bug/SKILL.md +166 -0
- package/.cursor/skills/yunxiao-task-management/SKILL.md +170 -258
- package/.cursor/skills/yunxiao-task-management/templates//346/217/220/346/265/213/345/215/225/346/250/241/346/235/277.html +17 -0
- package/AGENTS.md +91 -0
- package/CLAUDE.md +34 -0
- package/README.md +1 -1
- package/package.json +1 -1
- package/src/skills/analyze-requirements/SKILL.md +112 -0
- package/src/skills/fix-bug/SKILL.md +166 -0
- package/src/skills/yunxiao-task-management/SKILL.md +170 -258
- package/src/skills/yunxiao-task-management/templates//346/217/220/346/265/213/345/215/225/346/250/241/346/235/277.html +17 -0
package/AGENTS.md
CHANGED
|
@@ -83,6 +83,8 @@
|
|
|
83
83
|
| `brainstorm` | 头脑风暴、创意、方案设计 |
|
|
84
84
|
| `task-tracker` | 任务跟踪、进度管理 |
|
|
85
85
|
| `test-development` | 测试、单元测试 |
|
|
86
|
+
| `analyze-requirements` | 需求分析全流程编排(原型图/云效任务 → 开发任务清单) |
|
|
87
|
+
| `fix-bug` | 修复 Bug 全流程编排(排查+修复+提交) |
|
|
86
88
|
| `bug-detective` | Bug 排查、报错、异常 |
|
|
87
89
|
| `performance-doctor` | 性能优化、慢查询、缓存 |
|
|
88
90
|
| `add-skill` | 添加技能、创建技能文档 |
|
|
@@ -104,6 +106,95 @@
|
|
|
104
106
|
|
|
105
107
|
---
|
|
106
108
|
|
|
109
|
+
## 多模型分层 Agent 系统
|
|
110
|
+
|
|
111
|
+
> 按思维深度分层,不同 Agent 使用不同模型,各司其职。
|
|
112
|
+
|
|
113
|
+
### Haiku 层 — 数据获取(快、省)
|
|
114
|
+
|
|
115
|
+
| Agent | 模型 | 职责 | 触发场景 |
|
|
116
|
+
|-------|------|------|---------|
|
|
117
|
+
| `code-scanner` | haiku | 代码库扫描 + 文件定位 + 代码片段收集 | 任务开始前的代码探索、模块结构了解、相似实现查找 |
|
|
118
|
+
| `loki-runner` | haiku | Loki 日志查询 + 格式化 | Bug 排查、线上问题、traceId 追踪 |
|
|
119
|
+
| `mysql-runner` | haiku | MySQL 只读查询 + 格式化 | 数据排查、验证数据状态 |
|
|
120
|
+
| `task-fetcher` | haiku | 云效任务获取 + 整理 | 需求同步、任务查询 |
|
|
121
|
+
| `image-reader` | haiku | 截图/图片/Axure原型图内容提取 | 错误截图、表格截图、架构图、Axure原型分析 |
|
|
122
|
+
|
|
123
|
+
### Sonnet + Codex 层 — 代码分析(理解、推理)
|
|
124
|
+
|
|
125
|
+
| Agent | 模型 | 职责 | 触发场景 |
|
|
126
|
+
|-------|------|------|---------|
|
|
127
|
+
| `bug-analyzer` | sonnet | Bug 根因分析 + Codex 逻辑分析 | 接收 Haiku 层数据后分析根因 |
|
|
128
|
+
| `code-reviewer` | sonnet | 规范检查 + Codex 逻辑审查 | /dev、/crud 完成后、代码审查 |
|
|
129
|
+
|
|
130
|
+
### Opus 层 — 需求分析 + 架构决策 + 编码
|
|
131
|
+
|
|
132
|
+
| Agent | 模型 | 职责 | 触发场景 |
|
|
133
|
+
|-------|------|------|---------|
|
|
134
|
+
| `requirements-analyzer` | opus | 需求分析,协调 Haiku 层提取数据并输出开发任务清单 | Axure 原型分析、需求转开发任务 |
|
|
135
|
+
|
|
136
|
+
主会话也使用 Opus 模型,负责:
|
|
137
|
+
- 接收各层 Agent 的结构化结果
|
|
138
|
+
- 做出架构决策
|
|
139
|
+
- 编写核心业务代码
|
|
140
|
+
- 协调各层 Agent 工作
|
|
141
|
+
|
|
142
|
+
### 协作流程示例
|
|
143
|
+
|
|
144
|
+
```
|
|
145
|
+
功能开发流程:
|
|
146
|
+
Opus 主会话 → 启动 Haiku 层扫描
|
|
147
|
+
└─ code-scanner(Haiku) → 代码扫描报告(文件清单、关键片段、依赖关系)
|
|
148
|
+
│
|
|
149
|
+
▼ 基于扫描结果决策
|
|
150
|
+
Opus 主会话 → /dev 或 /crud 编写代码(不再自己做初始扫描)
|
|
151
|
+
│
|
|
152
|
+
▼ 代码完成
|
|
153
|
+
Opus 主会话 → 启动审查
|
|
154
|
+
└─ code-reviewer(Sonnet+Codex) → 审查报告
|
|
155
|
+
|
|
156
|
+
需求分析流程(analyze-requirements 技能编排):
|
|
157
|
+
Opus 主会话 → 复杂度判断
|
|
158
|
+
│
|
|
159
|
+
├─ 简单需求 → 直接分析输出任务清单 → 推荐 /crud 或 /dev
|
|
160
|
+
│
|
|
161
|
+
└─ 复杂需求 → 启动 requirements-analyzer(Opus)
|
|
162
|
+
└─ 按信息量并行调用 Haiku 层
|
|
163
|
+
├─ image-reader(Haiku) × N张 → 原型图结构(有截图时)
|
|
164
|
+
├─ task-fetcher(Haiku) → 云效任务信息(有任务号时)
|
|
165
|
+
└─ 汇总分析 → 输出需求分析报告 + 开发任务清单
|
|
166
|
+
│
|
|
167
|
+
▼ 按任务清单开发
|
|
168
|
+
Opus 主会话 → code-scanner(Haiku) 扫描 → /dev 编写代码
|
|
169
|
+
│
|
|
170
|
+
▼ 代码完成
|
|
171
|
+
Opus 主会话 → 启动审查
|
|
172
|
+
└─ code-reviewer(Sonnet+Codex) → 审查报告
|
|
173
|
+
|
|
174
|
+
Bug 修复流程(fix-bug 技能编排):
|
|
175
|
+
Opus 主会话 → 复杂度判断
|
|
176
|
+
│
|
|
177
|
+
├─ 简单 Bug → 直接读代码修复 → git-workflow 提交
|
|
178
|
+
│
|
|
179
|
+
└─ 复杂 Bug → 按信息量并行启动 Agent
|
|
180
|
+
├─ bug-analyzer(Sonnet+Codex) → 根因分析(必启动)
|
|
181
|
+
├─ loki-runner(Haiku) → 日志数据(有 traceId 时)
|
|
182
|
+
├─ mysql-runner(Haiku) → 数据库数据(有 DB 信息时)
|
|
183
|
+
└─ code-scanner(Haiku) → 相关代码结构(需要时)
|
|
184
|
+
│
|
|
185
|
+
▼ 汇总 Agent 结果
|
|
186
|
+
Opus 主会话 → 确认修复方案 → 编写修复代码
|
|
187
|
+
│
|
|
188
|
+
▼ 代码完成
|
|
189
|
+
Opus 主会话 → 启动审查
|
|
190
|
+
└─ code-reviewer(Sonnet+Codex) → 审查报告
|
|
191
|
+
│
|
|
192
|
+
▼ 审查通过
|
|
193
|
+
git-workflow 提交(必须通过技能,禁止直接 git commit)
|
|
194
|
+
```
|
|
195
|
+
|
|
196
|
+
---
|
|
197
|
+
|
|
107
198
|
## 🚨 强制执行规则
|
|
108
199
|
|
|
109
200
|
### 规则 1:任务匹配时必须读取技能
|
package/CLAUDE.md
CHANGED
|
@@ -208,6 +208,38 @@ CREATE TABLE [表名] (
|
|
|
208
208
|
);
|
|
209
209
|
```
|
|
210
210
|
|
|
211
|
+
## 开发模式选择指南
|
|
212
|
+
|
|
213
|
+
根据功能复杂度和开发类型,选择合适的工作流:
|
|
214
|
+
|
|
215
|
+
### 复杂度路由表
|
|
216
|
+
|
|
217
|
+
| 复杂度 | 判断标准 | 推荐工作流 | 说明 |
|
|
218
|
+
|--------|---------|-----------|------|
|
|
219
|
+
| **轻量** | 单表 CRUD、字段增删、简单查询 | `/dev` 或 `/crud` 直接开发 | 无需需求拆解 |
|
|
220
|
+
| **中等** | 2-3 张表联动、跨 Service 调用、状态流转 | `/dev` 开发(可选 OpenSpec) | 建议先理清逻辑再编码 |
|
|
221
|
+
| **复杂** | 多模块协作、复杂业务流程、需要设计评审 | OpenSpec → `/dev` | 先用 `/opsx:ff` 生成制品,再按 tasks 逐步实现 |
|
|
222
|
+
|
|
223
|
+
### 开发类型路由
|
|
224
|
+
|
|
225
|
+
| 类型 | 特征 | 工作流 |
|
|
226
|
+
|------|------|--------|
|
|
227
|
+
| **产品开发(core 迭代)** | 改 core 代码、会有后续迭代 | 复杂功能用 OpenSpec 拆解,简单功能直接 `/dev` |
|
|
228
|
+
| **项目定制(一次性)** | Dz 前缀类、dz_ 表、@Primary 覆盖 | 直接 `/dev`,参考 `leniu-customization-location` 技能 |
|
|
229
|
+
|
|
230
|
+
### OpenSpec 与 Commands 的关系
|
|
231
|
+
|
|
232
|
+
```
|
|
233
|
+
OpenSpec(思考) Commands(执行)
|
|
234
|
+
─────────────── ──────────────
|
|
235
|
+
proposal.md ────→ /dev(按 task 逐个开发)
|
|
236
|
+
specs/*.md ────→ /crud(快速生成 CRUD)
|
|
237
|
+
design.md ────→ /check(验证规范)
|
|
238
|
+
tasks.md ────→ /progress(跟踪进度)
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
> **原则**:OpenSpec 负责需求拆解和设计决策,Commands 负责代码生成和质量管控。简单任务跳过 OpenSpec,直接用 Commands。
|
|
242
|
+
|
|
211
243
|
## 快速命令
|
|
212
244
|
|
|
213
245
|
| 命令 | 用途 |
|
|
@@ -215,3 +247,5 @@ CREATE TABLE [表名] (
|
|
|
215
247
|
| `/dev` | 开发新功能 |
|
|
216
248
|
| `/crud` | 快速生成 CRUD |
|
|
217
249
|
| `/check` | 代码规范检查 |
|
|
250
|
+
| `/next` | 下一步建议(含 OpenSpec 变更扫描) |
|
|
251
|
+
| `/progress` | 项目进度(含 OpenSpec 状态) |
|
package/README.md
CHANGED
|
@@ -55,7 +55,7 @@ npx ai-engineering-init --tool claude
|
|
|
55
55
|
|
|
56
56
|
**更多命令**:`/crud`(生成增删改查)、`/progress`(项目进度)、`/sync`(代码状态同步)
|
|
57
57
|
|
|
58
|
-
> **包含内容**:
|
|
58
|
+
> **包含内容**:90 个 Skills 技能 + 10 个快捷命令 + 9 个多模型分层 Agent + 自动化 Hooks。详见 [参考文档](./docs/reference.md)。
|
|
59
59
|
|
|
60
60
|
## 初始化后使用
|
|
61
61
|
|
package/package.json
CHANGED
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: analyze-requirements
|
|
3
|
+
description: |
|
|
4
|
+
需求分析全流程编排。根据输入类型自动调度 Agent 获取数据,输出结构化需求报告和开发任务清单。
|
|
5
|
+
|
|
6
|
+
触发场景:
|
|
7
|
+
- 收到 Axure 原型截图需要分析需求
|
|
8
|
+
- 需要将产品需求转化为开发任务
|
|
9
|
+
- 云效任务需要拆解为开发步骤
|
|
10
|
+
- 需求评审前需要结构化分析
|
|
11
|
+
|
|
12
|
+
触发词:分析需求、需求分析、原型分析、需求拆解、分析原型图
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# 需求分析全流程
|
|
16
|
+
|
|
17
|
+
## 核心原则
|
|
18
|
+
|
|
19
|
+
**先判断复杂度,简单需求直接分析,复杂需求走 Agent 编排。分析完成后推荐开发流程。**
|
|
20
|
+
|
|
21
|
+
## 步骤 0:复杂度判断(必须先做)
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
用户提供需求线索
|
|
25
|
+
│
|
|
26
|
+
├─ 简单需求? ──→ 快速路径(直接分析输出任务清单)
|
|
27
|
+
│ - 纯文字描述,功能明确
|
|
28
|
+
│ - 单表 CRUD,无需看原型图
|
|
29
|
+
│ - 用户已给出完整字段列表
|
|
30
|
+
│
|
|
31
|
+
└─ 复杂需求? ──→ Agent 路径(启动 requirements-analyzer)
|
|
32
|
+
- 提供了 Axure 原型截图
|
|
33
|
+
- 提供了云效任务编号
|
|
34
|
+
- 多页面/多模块联动
|
|
35
|
+
- 业务流程复杂,需要状态流转设计
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## 快速路径(简单需求)
|
|
39
|
+
|
|
40
|
+
```
|
|
41
|
+
理解需求 → 设计表结构 → 列出接口清单 → 输出任务清单 → 推荐 /crud 或 /dev
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
不启动 Agent,直接在主对话中完成。输出格式参考下方"输出规范"。
|
|
45
|
+
|
|
46
|
+
## Agent 路径(复杂需求)
|
|
47
|
+
|
|
48
|
+
```
|
|
49
|
+
步骤 1:收集信息(从用户消息中提取)
|
|
50
|
+
- Axure 原型截图路径
|
|
51
|
+
- 云效任务编号
|
|
52
|
+
- 需求描述文字
|
|
53
|
+
- 关联模块信息
|
|
54
|
+
|
|
55
|
+
步骤 2:启动 requirements-analyzer Agent
|
|
56
|
+
└── requirements-analyzer(Opus) 内部自动编排:
|
|
57
|
+
├── image-reader(Haiku) × N张 → 提取原型图结构(有截图时)
|
|
58
|
+
├── task-fetcher(Haiku) → 获取云效任务详情(有任务号时)
|
|
59
|
+
└── 汇总分析 → 输出需求报告 + 任务清单
|
|
60
|
+
|
|
61
|
+
步骤 3:Opus 主会话接收报告 → 推荐开发流程
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## Agent 启动规则
|
|
65
|
+
|
|
66
|
+
### 按信息量决定启动方式
|
|
67
|
+
|
|
68
|
+
| 用户提供的信息 | 启动方式 |
|
|
69
|
+
|---------------|---------|
|
|
70
|
+
| 只有文字描述 | 快速路径(不启动 Agent) |
|
|
71
|
+
| 文字 + 原型截图 | requirements-analyzer → 内部调 image-reader |
|
|
72
|
+
| 文字 + 云效任务号 | requirements-analyzer → 内部调 task-fetcher |
|
|
73
|
+
| 原型截图 + 云效任务号 | requirements-analyzer → 内部并行调 image-reader + task-fetcher |
|
|
74
|
+
|
|
75
|
+
### 启动示例
|
|
76
|
+
|
|
77
|
+
```
|
|
78
|
+
# 有原型截图
|
|
79
|
+
Agent(subagent_type="requirements-analyzer",
|
|
80
|
+
prompt="分析以下 Axure 原型截图,输出需求分析报告和开发任务清单:
|
|
81
|
+
截图路径:/path/to/image1.png, /path/to/image2.png
|
|
82
|
+
需求描述:xxx")
|
|
83
|
+
|
|
84
|
+
# 有云效任务
|
|
85
|
+
Agent(subagent_type="requirements-analyzer",
|
|
86
|
+
prompt="获取云效任务 SARW-456 的详情,结合以下需求描述分析:xxx")
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
## 输出规范
|
|
90
|
+
|
|
91
|
+
无论走快速路径还是 Agent 路径,最终输出必须包含:
|
|
92
|
+
|
|
93
|
+
1. **业务概述** — 一段话描述需求
|
|
94
|
+
2. **数据库设计** — 建表 SQL(遵循项目规范)
|
|
95
|
+
3. **接口清单** — 路由 + 方法 + 说明
|
|
96
|
+
4. **开发任务拆解** — 按依赖排序的任务列表
|
|
97
|
+
5. **推荐开发流程** — 根据复杂度推荐
|
|
98
|
+
|
|
99
|
+
### 复杂度 → 开发流程推荐
|
|
100
|
+
|
|
101
|
+
| 复杂度 | 推荐流程 |
|
|
102
|
+
|--------|---------|
|
|
103
|
+
| 轻量(单表 CRUD) | `/crud` 生成 + `/dev` 补充 |
|
|
104
|
+
| 中等(2-3 表联动) | `/dev` 按任务逐步开发 |
|
|
105
|
+
| 复杂(多模块协作) | OpenSpec `/opsx:new` → `/opsx:ff` → `/opsx:apply` |
|
|
106
|
+
|
|
107
|
+
## 注意
|
|
108
|
+
|
|
109
|
+
- 简单需求不要过度编排,直接分析就行
|
|
110
|
+
- 与 `bug-detective` / `fix-bug` 的区别:本技能面向**新功能开发前的需求分析**,不涉及 Bug 排查
|
|
111
|
+
- 数据库设计必须遵循项目规范(雪花 ID、审计字段、del_flag=2 正常)
|
|
112
|
+
- 如果需求信息不完整,主动列出需要确认的点,而不是猜测
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: fix-bug
|
|
3
|
+
description: |
|
|
4
|
+
Bug 修复全流程编排。强制使用并行 Agent 模式进行排查,修复后走 git-workflow 提交。
|
|
5
|
+
|
|
6
|
+
触发场景:
|
|
7
|
+
- 修复 Bug(含日志/traceId/数据库信息)
|
|
8
|
+
- 线上问题排查与修复
|
|
9
|
+
- 报表数据不正确需排查修复
|
|
10
|
+
- 接口返回异常需定位修复
|
|
11
|
+
|
|
12
|
+
触发词:修复bug、fix bug、修复、排查修复、线上修复、bug修复
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# Bug 修复全流程
|
|
16
|
+
|
|
17
|
+
## 核心原则
|
|
18
|
+
|
|
19
|
+
**先判断复杂度,简单 Bug 直接修,复杂 Bug 走并行 Agent。修复后必须走 git-workflow 提交。**
|
|
20
|
+
|
|
21
|
+
## 步骤 0:复杂度判断(必须先做)
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
用户提供 Bug 线索
|
|
25
|
+
│
|
|
26
|
+
├─ 简单 Bug? ──→ 快速路径(直接读代码修复)
|
|
27
|
+
│ - 明显的代码错误(NPE、空判断遗漏、拼写错误)
|
|
28
|
+
│ - 用户已明确指出问题和修改方案
|
|
29
|
+
│ - 单文件改动,逻辑清晰
|
|
30
|
+
│ - 不需要查数据库/日志验证
|
|
31
|
+
│
|
|
32
|
+
└─ 复杂 Bug? ──→ Agent 路径(并行排查)
|
|
33
|
+
- 需要查日志确认线上行为(提供了 traceId)
|
|
34
|
+
- 需要查数据库验证数据正确性(提供了 DB 信息)
|
|
35
|
+
- 问题根因不明确,需要多维度分析
|
|
36
|
+
- 涉及多模块/多表关联的数据问题
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
## 快速路径(简单 Bug)
|
|
40
|
+
|
|
41
|
+
```
|
|
42
|
+
读代码 → 定位问题 → 修复 → 走 git-workflow 提交
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
不启动 Agent,直接在主对话中完成。
|
|
46
|
+
|
|
47
|
+
## Agent 路径(复杂 Bug)
|
|
48
|
+
|
|
49
|
+
```
|
|
50
|
+
步骤 1:收集信息(从用户消息中提取)
|
|
51
|
+
- traceId / 错误日志
|
|
52
|
+
- 数据库环境(host/port/库名)
|
|
53
|
+
- Loki 日志环境
|
|
54
|
+
- Bug 描述 / 期望行为
|
|
55
|
+
|
|
56
|
+
步骤 2:并行启动 Agent(必须同时启动,不串行)
|
|
57
|
+
├── bug-analyzer Agent: 读代码分析根因,给出修复方案
|
|
58
|
+
├── mysql-runner Agent: 查数据库验证数据(如提供了DB信息)
|
|
59
|
+
└── loki-runner Agent: 查 Loki 日志验证线上行为(如提供了traceId)
|
|
60
|
+
|
|
61
|
+
步骤 3:汇总 Agent 结果 → 确认修复方案
|
|
62
|
+
|
|
63
|
+
步骤 4:修复代码
|
|
64
|
+
|
|
65
|
+
步骤 5:走 git-workflow 提交
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
## Agent 启动规则
|
|
69
|
+
|
|
70
|
+
### 必须并行(单条消息多个 Agent tool call)
|
|
71
|
+
|
|
72
|
+
```
|
|
73
|
+
# 正确:一条消息同时启动 3 个 Agent
|
|
74
|
+
Agent(bug-analyzer, "分析 xxx 代码的 bug...")
|
|
75
|
+
Agent(mysql-runner, "查询 xxx 数据库验证...")
|
|
76
|
+
Agent(loki-runner, "查询 traceId xxx 的日志...")
|
|
77
|
+
|
|
78
|
+
# 错误:串行启动(等一个完再启动下一个)
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
### 各 Agent 职责
|
|
82
|
+
|
|
83
|
+
| Agent | subagent_type | 职责 | 输入 |
|
|
84
|
+
|-------|---------------|------|------|
|
|
85
|
+
| 代码分析 | `bug-analyzer` | 读代码、分析根因、给修复方案 | Bug 描述 + 相关文件路径 |
|
|
86
|
+
| 数据库验证 | `mysql-runner` | 查数据验证业务逻辑 | DB 连接信息 + 验证 SQL |
|
|
87
|
+
| 日志查询 | `loki-runner` | 查 Loki 日志看线上行为 | Loki 环境 + traceId |
|
|
88
|
+
|
|
89
|
+
### Agent 信息来源
|
|
90
|
+
|
|
91
|
+
**配置文件优先**,不存在时自动创建模板并提示用户填写:
|
|
92
|
+
|
|
93
|
+
| 配置 | 文件路径 |
|
|
94
|
+
|------|---------|
|
|
95
|
+
| MySQL | `.claude/mysql-config.json` |
|
|
96
|
+
| Loki | `.claude/skills/loki-log-query/environments.json` |
|
|
97
|
+
|
|
98
|
+
**配置获取流程**:
|
|
99
|
+
```
|
|
100
|
+
需要连 MySQL/Loki?
|
|
101
|
+
│
|
|
102
|
+
├─ 配置文件存在且有有效凭证? → 直接使用
|
|
103
|
+
│
|
|
104
|
+
├─ 配置文件存在但是占位符? → 提示用户填写敏感信息,等用户确认后继续
|
|
105
|
+
│
|
|
106
|
+
└─ 配置文件不存在? → 创建模板文件(占位符) → 提示用户填写 → 等确认后继续
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
**创建 MySQL 模板**:
|
|
110
|
+
```json
|
|
111
|
+
{
|
|
112
|
+
"environments": {
|
|
113
|
+
"test21": {
|
|
114
|
+
"name": "test21 测试环境",
|
|
115
|
+
"host": "YOUR_HOST",
|
|
116
|
+
"port": 3306,
|
|
117
|
+
"user": "YOUR_USER",
|
|
118
|
+
"password": "YOUR_PASSWORD",
|
|
119
|
+
"db_prefix": "testcore_",
|
|
120
|
+
"aliases": ["test21", "21"]
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
"default": "test21",
|
|
124
|
+
"mysql_path": "/opt/homebrew/opt/mysql-client/bin/mysql"
|
|
125
|
+
}
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
**创建 Loki 模板**:
|
|
129
|
+
```json
|
|
130
|
+
{
|
|
131
|
+
"active": "test13",
|
|
132
|
+
"environments": {
|
|
133
|
+
"test13": {
|
|
134
|
+
"name": "测试13(主测试环境)",
|
|
135
|
+
"url": "https://test13.xnzn.net/grafana",
|
|
136
|
+
"token": "YOUR_TOKEN",
|
|
137
|
+
"aliases": ["test13", "13"]
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
**敏感信息由用户手动填写,禁止 AI 将对话中的密码/token 写入配置文件。**
|
|
144
|
+
|
|
145
|
+
### 按信息量决定启动哪些 Agent
|
|
146
|
+
|
|
147
|
+
| 用户提供的信息 | 启动的 Agent |
|
|
148
|
+
|---------------|-------------|
|
|
149
|
+
| 只有 Bug 描述 | bug-analyzer |
|
|
150
|
+
| Bug 描述 + traceId | bug-analyzer + loki-runner |
|
|
151
|
+
| Bug 描述 + DB 信息 | bug-analyzer + mysql-runner |
|
|
152
|
+
| Bug 描述 + traceId + DB 信息 | bug-analyzer + mysql-runner + loki-runner(全部) |
|
|
153
|
+
|
|
154
|
+
## 提交规则
|
|
155
|
+
|
|
156
|
+
修复完成后,**必须调用 `Skill(git-workflow)` 再执行 git 操作**。
|
|
157
|
+
|
|
158
|
+
禁止:
|
|
159
|
+
- 直接 `git commit && git push` 跳过技能
|
|
160
|
+
- 在 Agent 内部执行 git 操作
|
|
161
|
+
|
|
162
|
+
## 注意
|
|
163
|
+
|
|
164
|
+
- 简单 Bug 不要过度编排,直接修就行
|
|
165
|
+
- 如果用户没提供 DB/Loki 信息但 Bug 涉及数据问题,主动询问
|
|
166
|
+
- 与 `bug-detective` 技能的区别:`bug-detective` 是排查指南,`fix-bug` 是全流程编排(包含排查+修复+提交)
|