mirror of
https://github.com/laoxong/nofx.git
synced 2026-06-04 01:48:22 +08:00
3ca95b294d
* feat: integrate NOFXi agent into dev * Enhance NOFXi agent workflow and diagnostics
5.6 KiB
5.6 KiB
NOFXi 诊断与配置 Skills(第一批)
这份文档用于沉淀交易智能助手的第一批高频诊断与配置 skill。
目标不是让模型“更会想”,而是让它面对常见问题时,优先走稳定、可复用的排查路径。
设计原则
- 优先按 skill 回答,不要对高频问题重复自由规划
- 先归类问题,再给出原因、检查项和修复建议
- 能通过工具验证当前状态时,先查再下结论
- 敏感信息只指导填写,不完整回显
- 对结论不确定时,要明确标注为“更可能”或“优先怀疑”
skill_model_api_setup
适用场景
- 用户问某个大模型的 API key 去哪里申请
- 用户问 base URL 怎么填
- 用户问 model name 怎么填
- 用户问 OpenAI / Claude / Gemini / DeepSeek / Qwen / Kimi / Grok / MiniMax 怎么接入
处理策略
- 先确认用户要配置哪个 provider
- 告诉用户需要准备的最少字段:
- provider
- API key
- custom_api_url
- custom_model_name
- 如果系统已有默认地址和默认模型名,优先给推荐值
- 回答按步骤组织,不要泛泛解释概念
已知实现事实
- 系统内置 provider 默认运行配置,见
agent.resolveModelRuntimeConfig(...) - 常见 provider 已有默认 URL 和默认 model name
skill_model_config_diagnosis
适用场景
- 模型保存成功但 agent 仍然不可用
- 提示 AI unavailable
- 提示模型没启用
- 提示 custom_api_url 不合法
- 配置后 trader 不生效
优先排查
- 是否存在已启用模型
- API key 是否为空
- custom_api_url 是否为合法 HTTPS 地址
- custom_model_name 是否为空或不匹配
- 当前 trader 是否绑定了这个模型
- 更新模型后是否已触发 trader reload
已知实现事实
- 非 HTTPS 的
custom_api_url会被后端拒绝,见api/handler_ai_model.go - 已启用模型如果缺少 API Key 或 URL,会导致 agent 无法就绪,见
agent.ensureAIClientForStoreUser(...) - 更新模型配置后,系统会尝试移除并重载相关 trader,使新配置立即生效
输出格式
- 现象
- 更可能原因
- 先检查什么
- 下一步怎么修复
skill_exchange_api_setup
适用场景
- 用户要新建交易所 API
- 用户不知道交易所需要哪些权限
- 用户问 API key / secret / passphrase 分别填什么
通用处理策略
- 先确认交易所类型
- 告知必须权限与禁止权限
- 告知是否需要额外字段
- 强调 IP 白名单与权限配置
- 引导用户回到系统内完成绑定
特殊规则
- OKX 除 API Key 和 Secret 外,还需要 passphrase
- Bybit 永续/合约交易需要合约权限
- 不建议开启提现权限
参考文档
docs/getting-started/okx-api.mddocs/getting-started/bybit-api.md
skill_exchange_api_diagnosis
适用场景
invalid signaturetimestamp错误IP not allowedpermission denied- 交易所连接不上
优先排查
- 系统时间是否同步
- API Key / Secret 是否正确
- 是否遗漏额外字段,如 OKX passphrase
- IP 白名单是否包含当前服务器
- 是否启用了交易或合约权限
- 密钥是否过期或已重建
已知实现事实
- 时间不同步是
invalid signature/timestamp的高频根因,见docs/guides/TROUBLESHOOTING.zh-CN.md - OKX 的 passphrase 缺失会导致签名相关问题,见
docs/getting-started/okx-api.md
输出格式
- 报错现象
- 最常见根因
- 优先检查顺序
- 修复步骤
skill_trader_start_diagnosis
适用场景
- trader 启动不了
- trader 启动了但没开始交易
- 页面显示已启动但一直没有动作
- 用户怀疑 strategy / model / exchange 绑定有问题
优先排查
- 是否有已启用的模型配置
- 是否有已启用的交易所配置
- trader 是否绑定了 exchange_id / strategy_id / ai_model_id
- 交易所余额和权限是否满足下单条件
- AI 最近的决策到底是 wait、hold 还是下单失败
回答原则
- 要区分“没启动”“启动了但 AI 选择不交易”“尝试下单但失败”这三类
- 不要把“没开仓”直接等同于“系统故障”
skill_order_execution_diagnosis
适用场景
- 下单失败
- 只开空不开户 / 只开单边
- 杠杆报错
- position side mismatch
优先排查
- 账户模式是否匹配,例如 Binance 是否为 Hedge Mode
- 是否为子账户杠杆限制
- 合约权限是否开启
- 余额、保证金、可交易 symbol 是否满足条件
已知实现事实
- Binance 在 One-way Mode 下,可能出现
position side mismatch或单边行为 - 某些子账户杠杆上限较低,超过限制会直接失败
- 这些问题在
docs/guides/TROUBLESHOOTING.md已有明确说明
skill_strategy_diagnosis
适用场景
- 用户说策略没生效
- 用户说 prompt 预览和实际不一致
- 用户说修改策略后 trader 行为没有变化
优先排查
- 当前编辑的是策略模板,还是 trader 的 custom prompt
- 策略是否真的保存成功
- 是否需要重新读取当前配置做对比
- 用户说的“没生效”是指未保存、未绑定,还是运行结果与预期不一致
回答原则
- 先明确“对象”再排查:strategy template / trader / prompt override
- 如果能读取当前保存值,就不要凭印象判断
后续扩展方向
下一批可以继续补:
skill_balance_and_position_diagnosisskill_market_data_diagnosisskill_prompt_generation_diagnosisskill_strategy_test_run_diagnosisskill_exchange_specific_setup_<exchange>skill_model_provider_setup_<provider>